<Insert Picture Here> Introduction to and What’s New with Oracle Spatial 11g, Oracle Multimedia, and Oracle’s Semantic Database Alexander Ryndin, Oracle CIS Содержание • Управление неструктурированными данными • Пространственные данные • Стратегия • Позиция на рынке • Технологии и продукты • Новое в пространственных данных • Новое в Semantic • Новое в Multimedia • Дискуссия <Insert Picture Here> Управляем неструктурированными данными Oracle SecureFiles High Performance, Secure LOBs • Единое хранилище для данных и метаданных • Масштабируемое • Безопасное • Высокодоступное • Интегрированное • Надежное • Доступное на всех платформах XML DB Integrated Native XML Database Oracle Text Text Indexing and Classification Location & Spatial Location Enabled Databases Multimedia Audio, Image and Video New with 11g: DICOM Medical Imaging Relational Characters, Numbers, Dates Управляем неструктурированными данными Location & Spatial Location Enabled Databases Multimedia Audio, Image and Video New with 11g: DICOM Medical Imaging Основные тенденции в ГИС • «Продвинутые» заказчики • • Любой может купить GPS – Handhelds/ Car Navigation Используют Google Maps, Google Earth • Web интерфейс для заказчиков и граждан • На карте можно увидеть информацию о недвижимости, трафике и т.д. • Геосервисы должны быть надежными • • Доступны и безопасны 01, 02, 112, МЧС, Энергетика, Telcos, Коммунальные службы, Дороги • Отслеживаем все что движется • • Определить местоположение, найти ближайший, посмотреть историю Люди, оборудование, госпитали, самолеты, машины, дороги, вода • Базы данных растут (TB->PB) • • Аэрофотосъемка, спутниковые снимки Архивы с длительным хранением (без срока давности!) Пространственные данные и IT Сосуществование или интеграция? • Специальные серверы для различных типов данных • Изоляция данных • Множество закрытых форматов • Высокие ИТ и управленческие расходы Проблемы масштабируемости Высокие расходы на обучение Трудности поддержка GIS GIS Applications Enterprise IT Database Applications Что предлагает Oracle? Intranet GIS Oracle MapViewer, Oracle Maps, 3rd party GIS Просмотр, анализ и простое редактирование Расширенный анализ и редактирование Desktop GIS Autodesk Map 3D MapInfo ArcGIS Bentley Map CSoft MapDrive etc ORACLE ORACLE SPATIAL Корпоративные ГИС данные GEORASTER Спутниковые снимки и фотограмметрия NETWORK MODEL Сетевые данные TOPOLOGY MODEL Топология SPATIAL WEB SERVICES ГИС данные партнеров Публичные данные Web Portal Oracle MapViewer Oracle Maps 3rd party GIS Запросы данных, обмен данными решения Oracle решения Oracle и партнеров решения партнеров Какие пространственные технологии есть у Oracle? • Oracle Locator+Spatial: компонент Oracle Database XE, SE, EE и платная опция Oracle Database EE • MapViewer: компонент Oracle Application Server, позволяющий отрисовывать карту • GeoMap: JDeveloper ADF компонент • Комплект карт: основные дороги, административное деление (города, регионы) — от Navteq Oracle Locator Oracle Spatial 11g Включено в Oracle Database - ВСЕ Редакции Опция к Oracle Database Enterprise Edition • Поддержка всех геометрических типов • Поддержка 2D данных • Все пространственные операторы • Функции проверки корректности и расстояния • Полная поддержка систем координат • Пакеты утилит & тюнинга • Длинные транзакции • Параллельные пространственные запросы & построение индексов • Секционированные таблицы • Объектная репликация • Все возможности Locator • Дополнительные пространственные функции - вычисление площади/длины - буфер, центроид, объединение и т.д. • Линейная система координат (Linear Referencing Support) • Пространственное агрегирование • Тип данных GeoRaster • Топологическая модель данных • Сетевая модель данных • Механизм геокодирования • Пространственные аналитические функции • Поддержка 3D • OGC Web Services Oracle Spatial использует мощь Oracle Database • Секционирование таблиц • Для масштабируемых решений, управляемости и производительности • Label Security • Политики безопасности до уровня строки • Spatial Analysis через SQL • Используются открытые пространственные типы данных • Пространственные приложения не всегда нуждаются в полноценной ГИС • • • • • Spatial Analysis в хранимых процедурах, триггерах, фукнциях Репликация Встроенная в базу данных поддержка длинных транзакций Архитектура Grid SQL Developer Что такое Oracle Spatial? Непространственные данные НАЗВАНИЕ ШТАТА Пространственные данные: столбец типа SDO_GEOMETRY СТОЛИЦА CALIFORNIA Sacramento TEXAS Austin GEOM • Oracle Spatial это интегрированный набор функций и процедур базы данных Oracle, который позволяет быстро и эффективно хранить, получать доступ и анализировать пространственные данные. • Oracle Spatial поддерживает широкий спектр программного обеспечения — от ГИС (геоинформационных систем) до беспроводных пространственных сервисов и пространственноориентированного электронного бизнеса. Типы геометрических примитивов Point Oriented point Line string Compound line string Polygon Polygon with one or more holes Compound polygon Optimized polygons Self-crossing line strings valid Arc line string Arc polygon Self-crossing polygons not valid Загрузка данных • MapBuilder и Shapeloader • Инструментарий третьих фирм (Safe Software FME) Инструменты от вендоров программного обеспечения ГИС • Язык SQL для создания и заполнения данных. Загрузка данных: Shapefile Converter • Oracle’s Java-based инструмент: • Доступен в Oracle Database 11g и в Oracle Database 10gR2, в других версиях скачивается с OTN: • http://www.oracle.com/technology/software/products/spatial/fil es/shape2sdojava.zip http://www.oracle.com/technology/software/products/spatial/files/shape2sdoj ava.zip • Обрабатывает один ESRI shapefile за раз • Обрабатывает атрибутный (.DBF) и геометрические (.SHP and .SHX) файлы • Автоматически загружает таблицу с атрибутами и данными • Может создавать новую таблицу или загружать в существующую • Автоматически добавляет метаданные в USER_SDO_GEOM_METADATA представление Загрузка данных: Shapefile Converter • Входной файл: states • Processes STATES.SHP, STATES.SHX, and STATES.DBF • Результат: • Table: geod_states • Column: geom • SRID: 8307 Set clpath=.;%ORACLE_HOME%\jdbc\lib\ojdbc5.jar; %ORACLE_HOME%\md\jlib\sdoutl.jar; %ORACLE_HOME%\md\jlib\sdoapi.jar java -cp %clpath% oracle.spatial.util.SampleShapefileToJGeomFeature -h localhost -p 1521 -s orcl -u student -d student -t geod_states -f states -r 8307 -g geom Пространственный анализ данных Boundary • Простейшие операции • Area, Length, Envelope, Boundary и т.д. Within Intersect Touch • Операции для определения отношения между объектами • Equal, Disjoint, Intersect, Touch, Within и т.д. Buffer SymDiff • Пространственный анализ • Distance, Buffer, Union, Intersection, ConvexHull, SymDiff и т.д. Пространственный анализ: SDO_ANYINTERACT • Найти все парки в штате Wyoming SELECT p.id, p.name FROM us_parks p, us_states s WHERE s.state = 'Wyoming' AND SDO_ANYINTERACT ( p.geom, s.geom ) = 'TRUE'; Пространственный анализ: SDO_WITHIN_DISTANCE Найти все индийские рестораны в радиусе 5 км от отеля Bengali Curry House Главная улица SELECT r.restaurant_name FROM restaurants r, hotels h 5 км WHERE r.restaurant_type = ‘INDIAN’ AND h.hotel_name = ‘HILTON’ AND SDO_WITHIN_DISTANCE( r.location, h.location, Le Madras ‘distance=5 unit=km’) = ‘TRUE’; Отель Hilton Oracle Spatial 11g Enables Scrollable, Interactive Maps Spatial Web Services 3D, Point Clouds, and LIDAR Open Location Service Geocoding & Routing Oracle BI Dashboards Raster Imagery Растровые данные Векторные • Источники растровых данных: Растровые • Дистанционное зондирование (спутниковые данные, аэрофотосъемка) • Сканирование карт • Геология, геофизика, геохимия и т.д. • Накопление «сырых» данных • Оцифровка GeoRaster • Новый тип данных для хранения растровых данных • Спутниковые снимки, данные дистанционного зондирования • Многополосные • Информация о привязке • Функционал • Хранение и индексация растровых данных • Нет ограничений на размер объектов • Генерация пирамид разрешение • Предоставление доступа • TIFF, GeoTIFF, JPEG, GIFF формат Resolution Pyramid Pyramid Level 2 Pyramid Level 1 Pyramid Level 0 (Raw Data) Pyramid Level Геокодирование: • Позволяет сгенерировать долготу/широту по адресу и обратно • Поддержка стандартов различных стран • Форматированные и неформатированные адреса • Параметры поиска «нечеткого» соответствия • 100% Java, открытый и масштабируемый • По записям или батчами • Данные для геокодирования предоставляются специальными вендорами One Oracle Drive, Nashua NH, 03062 SELECT SDO_GCDR.GEOCODE ('ODF_EU_q108', SDO_KEYWORDARRAY('Пионерский проспект‘, 'Анапа 20'), 'RU', 'DEFAULT') GEO_ADDR FROM DUAL Example: House Level Match SELECT SDO_GCDR.GEOCODE('SPATIAL', SDO_KEYWORDARRAY('1350 Clay', 'San Francisco, CA'), 'US', 'DEFAULT') GEO_ADDR FROM DUAL; SDO_GEO_ADDR(0, SDO_KEYWORDARRAY(NULL), NULL, 'CLAY ST', NULL, NULL, 'SAN FRANCISCO', NULL, 'CA', 'US', '94109', NULL, '94109', NULL, '1350', 'CLAY', 'ST', 'F', 'F', NULL, NULL, 'L', .49, 23600696, '????#ENU??B281CP?', 2, 'DEFAULT', -122.41522, 37.7930729, '????0101410??004?') MATCHCODE 2 = тип улицы не совпал Точное совпадение по номеру дома на улице Clay St Почтовый индекс и название улицы заполнено Линейная привязка (LRS) Часто используется во многих GIS приложениях: • транспортные задачи (сеть дорог) КМ 60 • коммуникации (нефте- и газопроводы) Километровый столб 0 Километровый столб 27 (50,15,53.8) (30,10,27) (5,10,0) (45,10,44) (15,5,11.2) (40,5,38) (55,20,60) Сетевая модель данных • Сетевая модель данных • Модель данных хранить сетевую (графовую) структуру в базе данных • Сохраняет и поддерживает связи в сети • Хранить атрибуты связей и узлов • Трассировка & Маршрутизация • Транспортные решения • Логистика • Сервисы на основе местоположения, телематика • Bio-Info (Life Sciences) • Иерархические сети • Scale-free Networks Новые возможности Oracle Spatial 11g Сетевая модель с загрузкой «по требованию» • Используется та же самая сетевая модель в базе данных • Поддержка сетевых ограничений и пользовательских данных (new in 11g) • Сетевые разделы (partitions) загружаются во время анализа «на лету» по мере надобности • Не требуется загружать всю сеть в оперативную память • Учитывает динамические изменения • Предоставляются утилиты для управления разделами • Java и XML API Маршрутизация Routing Client Routing Engine (running in Oracle Application Server or OC4J) • Позволяет запустить XML-based Web services, которые • По запросу на муршрутизацию (начало, конец маршрута в виде адреса или координат) выдают маршрутную информацию (направление, расстояния, приблизительное время на маршрут и геометрию, представляющую маршрут) • То же самое, но с батчем маршрутов • Поддерживается международная маршрутизация • Интегрирован с Geocoder Oracle Application Server MapViewer • MapViewer: компонент Oracle Application Server, позволяющий отрисовывать карту • GeoMap: JDeveloper ADF компонент • Простая публикация карт в web • Javascript, Java, XML и PL/SQL APIs • Разработано для Java программистов Комплект карт MapViewer архитектура Browser/Apps Клиент Middle-tier: Oracle Application Server XML/HTTP, Java, JSP tag library, OGC WMS APIs MapViewer JDBC База данных Oracle Mapping Spatial/Lo metadata cator Map Builder (metadata admin tool) Пространственный анализ и карты в инструментах Oracle, Applications и BI Oracle JDeveloper Oracle Applications Oracle BI EE MapBuilder Что нового в MapViewer? • Сертифицирован для WebLogic Server версий 10 и 10.3 • Мощный открытый JavaScript/AJAX картографический API для интерактивной работы с картой на стороне клиента • Поддержка Safari • Поддержка ESRI Shape файлов • Поддержка разделения доступа к объектами • Поддержка OGC Web Feature Server тем и тектов аннотаций • Улучшены возможности подписей, текстовых стилей и отрисовки объектов • Поддержка вывода в PDF • Улучшена поддержка непространственных провайдеров и API для внешних пространственных провайдеров Управляем неструктурированными данными Location & Spatial Location Enabled Databases Multimedia Audio, Image and Video New with 11g: DICOM Medical Imaging Семантическая паутина (Semantic Web) • Семантическая паутина - часть глобальной концепции развития Интернет, целью которой является реализация возможности машинной обработки информации, доступной в Internet. • Основной акцент - работа с метаданными, однозначно характеризующими свойства и содержание ресурсов Всемирной паутины, вместо используемого в настоящее время текстового анализа документов. • Документы предназначены для восприятия человеком, метаданные используются машинами (поисковыми роботами и другими интеллектуальными агентами) для проведения однозначных логических заключений Языки описания Онтология (в информатике) — это попытка всеобъемлющей и детальной формализации некоторой области знаний с помощью концептуальной схемы. RDF - простой способ описания данных в формате субъектотношение-объект (в качестве любого элемента тройки используются URI) Standar ds based RDF Schema описывает набор атрибутов, таких, как rdfs:Class и rdfs:subClassOf. OWL - семейство языков для описания онтологий (расширяет возможности по описанию новых типов, позволяет описывать новые типы данных RDF Schema в терминах уже существующих) 36 Пример: семья А B C • :Павел - :Мужчина, :Антон – :Петр : Маша :Мужчина А • :Вера – :Женщина. • У :Кати и :Павла:Женя есть дети: :Александр : Миша :Миша и :Лена :Лена А А B :родитель • :Лена сестра :Александра :Антон :Вера :Павел :Катя • У :Антон и :Веры есть дети: :Александр и :Женя А :Женщина • У :Александра и :Лены есть дети :Мужчина :Петр и :Маша отец мать C :бабушка B C D E свойство C :кузен E B Использование 11gR1 RDF/OWL: шаг 1 • Создать таблицу для приложения • create table app_table (triple sdo_rdf_triple_s); • Создать семантическую модель • exec sem_apis.create_sem_model (‘family’,’app_table’,’triple’); • Загрузить данные, используя DML, Bulk или Batch loader • insert into app_table (triple) values(1, sdo_rdf_triple_s(‘family',‘Антон’,‘Отец’,‘Александр’ )); • insert into app_table (triple) values(2, sdo_rdf_triple_s(‘family',‘Антон’,‘Отец’,‘Петр’)); • Создать набор правил • INSERT INTO mdsys.semr_user_rulebase VALUES (‘Правило_брат','(?x <Отец> ?y)(?x <Отец> ?z)', NULL, '(?y <Брат> ?z)', null); 38 Использование 11gR1 RDF/OWL: шаг 2 • Собрать статистику • Запустить процедуру построения выводов • exec sem_apis.create_entailment (‘family_idx’,sem_models(‘family’), sem_rulebases(‘famowl’)); • Выполнить запрос к исходной и выведенной модели • select p, o from table(sem_match(‘Александр’ ?p ?o)', sem_models(‘family'), sem_rulebases(‘famowl’), null, null)); Semantic Data Management Workflow Транзакционные системы Неструктурир. данные RSS, email Редактирование & Преобразование • Вычленение & преобразование сущностей • Построение онтологии • Категоризация Другие данные • Скриптование Загрузка, выборка & построение выводов Partners Анализ • Управление данными RDF/OWL • Визуализация графов • SQL & SPARQL запросы • Анализ связей • Построение выводов • Семантические правила • Масштабируемость & Безопасность Data Sources Приложения & • Статистический анализ • Поиск полезных знаний • Выявление закономерностей • Text Mining Partners Партнеры в Semantic технологиях Управление RDF/OWL графовыми данными в Oracle 11g Key Capabilities: • Oracle 11g – лидирующая коммерческая база данных со встроенной поддержкой RDF/OWL данных • Масштабируемая & безопасная платформа для широкого круга семантических приложений • Масштабируется до громадных репозитариев (более 1 млрд.) • SQL или SPARQL запросы • Может использовать Oracle Partitioning, Advanced Compression, RAC • Растущее количество 3rd party инструментов Load / Storage Query • Встроенное хранилище RDF •Управление млрд. «троек» • Fast batch, bulk и incremental загрузки • SQL: SEM_Match • SPARQL: через Jena plug-in • Ontology assisted query of RDBMS data • Forward chaining model Reasoning • RDFS++ OWL, OWL Prime • Пользовательская база правил Управляем неструктурированными данными Location & Spatial Location Enabled Databases Multimedia Audio, Image and Video New with 11g: DICOM Medical Imaging Oracle Multimedia … • Поставляется уже 11 лет и предлагает возможности • По хранению, управлению и работе с мультимедийными объектами • Встроенная поддержка изображений, аудио и видео • Предоставляет возможности для • Извлечения метаданных • Преобразования и обработки изображений • Поддержка работы с потоками • Пользователи могут разрабатывать Oracle Multimedia приложения с использование таких инструментов как Application Express, Oracle JDeveloper, Oracle Portal • Полная поддержка SecureFiles (2-7 раз быстрее) • Поддержка объектов до 128 TB Oracle Multimedia и поддержка DICOM Новое в Oracle Database 11g Multimedia • DICOM (англ. Digital Imaging and Communications in Medicine) — основной стандарт для обработки, хранения и пересылки изображений в медицине. • DICOM - не только отдельные изображения, но и кинопетли, звук, информация о пациенте, исследовании, оборудовании, учреждении, о медиках, производящих, заказывающих исследования и т. д. • DICOM позволяет производить интеграцию сканеров, серверов, АРМов, принтеров и другого медицинского оборудования от разных продавцов в единую систему передачи и архивирования медицинской информации. • В Oracle Database 11g встроена поддержка DICOM Anatomical part SNOMED Code Alias Translation Skull T-11100 Maxilla and 头骨 Maxilla Mandible T11170 T-D1217 Mandible 上颌骨 Jaw T-11180 上下颌骨 下颌骨 DICOM в Oracle Database 11g • Полная поддержка DICOM стандарта для хранения • Механизм валидации проверяет заданные пользователем правила на метаданные DICOM • Механизм анонимизации • Извлечение/маппинг DICOM метаданных в XML – стандартных для DICOM и вендорных атрибутов для индексации и поиска • Функциональное APIs • Создание DICOM объектов из не-DICOM изображений • Масштабирование/сжатие/обрезка DICOM изображений • Поддержка преобразования форматов для мультифреймовых DICOM изображений Интеграция Medical Imaging с DBMS Client / Web Health Care Application Database Application Logic Application Server Logic PL/SQL, Java, C ... APIs DICOM Operations Native DICOM Storage XML DB, Java Virtual Machine, Query, Index SecureFile LOBs ASM Storage Device Case Studies BioGrid Australia • Это платформа и инфраструктура, которая предоставляет исследователям доступ к данным • По множеству болезней • Из различных разрозненных баз данных, из различных институтов • Соблюдая тайну частной жизни и интеллектуальную собственности • Собирается в виртуальный репозиторий • Связана с публичными репозиториями • Предоставляем гибкий и безопасный метод доступа к источникам медицинских данных для авторизованных исследователей Почему Oracle? • Изображения можно получать по требованию • Есть индексация и партицирование для ускорения запросов • Есть DICOM тип данных с богатым набором возможностей • SQL*Loader умеет быстро загружать изображения • Широкие возможности по обеспечению безопасности • Компрессия в LOB, в резервных копиях, DataPump • Application Express для быстрой разработки • Oracle Multimedia (включая DICOM) – бесплатная возможность Oracle Database Enterprise Edition Работа с DICOM: создание таблицы • CREATE TABLE medical_image_table (id varchar(50), TAPE_ID number, dicom orddicom, USI varchar(50) ) LOB (dicom.source.localdata) STORE AS SECUREFILE (COMPRESS HIGH) PARTITION BY range (TAPE_ID) (PARTITION PART1 VALUES less than (50) TABLESPACE TBLS_PART1_FROM_TAPE1); Работа с DICOM: преобразование в JPEG и анонимизация declare dcm ordsys.orddicom; begin ord_dicom.setDatamodel; for rec in (select * from medical_image_table for update) loop rec.dicom.setProperties(); -- create a JPEG thumbnail rec.dicom.processCopy('fileFormat=jpeg fixedScale=75,100', rec.imageThumb); -- make a new anonymous version of the ORDDicom object rec.dicom.makeAnonymous(genUID(rec.id), rec.anonDicom); -- write the objects back to the row …….. end loop; commit; e Работа с DICOM: импорт, экспорт CONNECT / AS SYSDBA --Directory IMAGEDIR for export/import DICOM create or replace directory imagedir as 'O:\ORACLE_DICOM_IMAGES'; grant read,write on directory IMAGEDIR to Administrator; -- importFrom ord_dicom.importFrom(dest, 'file', 'IMAGEDIR', 'example.dcm'); -- export() method can be used to export dcmSrc.export('FILE', 'IMAGEDIR', filename); Работа с DICOM: компрессия DICOM images are stored as SECUREFILE (COMPRESS HIGH) Achieves highest compression level • DICOM image size on file system: 1.48TB=1515.52GB • Database size: 820GB (less 3-4GB for other tables) Overall compression: (1515-816)/1515= approx. 46% ALEXANDER RYNDIN Spatial Senior Sales Consultant Presale Consulting Oracle CIS Moscow, Krasnopresnenskaya nab., 18, Block C phone +7(495) 641-1400 fax +7(495) 641-1414 [email protected] http://www.oracle.com/ http://www.oraclegis.com/ Find out more... • oracle.com/database/spatial.html Q&A • oracle.com/technology/products/spatial • oracle.com/technology/tech/semantic_technologies • oracle.com/technology/products/multimedia