Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
UML.doc
Скачиваний:
6
Добавлен:
16.11.2019
Размер:
8.2 Mб
Скачать

Р ис.62. Объектный просмотр, зависящий от объектного типа и реляционных таблиц

Соответствующий объектному просмотру, изображенному на рисунке 62, SQL скрипт имеет следующий вид:

CREATE OR REPLACE TYPE HR.OTV1 AS OBJECT (

JOB_ID VARCHAR2(10),

JOB_TITLE VARCHAR2(35),

REGION_ID NUMBER(2,6),

REGION_NAME VARCHAR2(25));

объектный тип OTV1, предок для OV1

CREATE OR REPLACE VIEW HR.OV1 OF HR.OTV1

WITH OBJECT OID (JOB_ID) AS

SELECT JOBS.JOB_ID, JOBS.JOB_TITLE,

REGIONS.REGION_ID, REGIONS.REGION_NAME

FROM HR.JOBS,HR.REGIONS

WHERE REGION_NAME LIKE '%TYMEN%';

объектный просмотр OV1 типа OV1, идентификатор объектов просмотра – JOB_ID

задействованные таблицы

условие выборки

Генерация объектных таблиц (Object Tables)

О бъектные таблицы позволяют помещать объектные типы в реляционную структуру. Каждый картеж объектной таблицы содержится в объекте. Атрибутам таблицы соответствуют свойства объектного типа. Пример изображения объектной таблицы на схеме БД приведен на рисунке 63.

Рис.63. Объектная таблица, определенная на основе объектного типа

Для объектной таблицы, изображенной на рисунке 63, SQL скрипт имеет следующий вид:

CREATE TABLE HR.RT_CUSTOMER OF HR.CUSTOMER;

объектная таблица типа CUSTOMER

Генерация коллекций (VARRAYs)

Коллекция – тип, создаваемый как упорядоченная последовательность элементов одного типа (массив). Тип элементов может быть как скалярным, так и объектным. коллекция может быть использованы в качестве типа для свойств объектов или атрибутов таблиц.

П ри определении коллекции указывается максимальное число элементов, которое она может содержать. Пример изображения коллекции объектных типов с максимальным числом элементов равным 30 представлен на рисунке 64.

Рис.64. Коллекция объектных типов

Соответствующий коллекции, изображенной на рисунке 64, SQL скрипт имеет следующий вид:

CREATE TYPE HR.OVAR1 AS VARRAY(30) OF HR.OTV1;

коллекция элементов типа OTV1

Генерация встраиваемых таблиц (Nested Tables)

Встраиваемые таблицы – особый вид таблиц, которые могут вкладываться в другие таблицы или объектные типы в качестве их атрибутов или свойств. Пример встраиваемой таблицы объектного типа, вложенной в реляционную таблицу, изображен на рисунке 65.

Рис.65. Встраиваемая таблица и связанные с ней элементы.

Для изображенной на рисунке 65 схемы, SQL скрипт имеет следующий вид:

CREATE TYPE HR.NT1 AS TABLE OF HR.CUSTOMER;

встраиваемая таблица типа CUSTOMER

CREATE TABLE HR.RTWNT1 (

ID NUMBER(5,5) NOT NULL UNIQUE,

NT HR.NT1,

CONSTRAINT RTWNT1_PK PRIMARY KEY (ID))

NESTED TABLE NT STORE AS NT_NTS;

реляционная таблица

NT – вложенная таблица типа NT1

Генерация реляционных таблиц (Relational Tables)

Атрибуты реляционных таблиц представлены атрибутами классов. Ограничения первичных ключей и индексы представлены в виде скрытых (implementation) атрибутов классов, со значениями инициализации, соответствующими атрибутам, для которых они определены. Ограничение внешнего ключа определяется через однонаправленную связь-ассоциацию от таблицы потомка (ссылающейся) к таблице предку (ссылочной). Имени ограничения соответствует имя связи; атрибуту внешнего ключа – имя утончающего (Key/Qualifier) связь атрибута; значение, инициализирующее утончающий атрибут, – уникальный ключ, на который ссылается определяемый таким образом внешний ключ. Редактировать параметры атрибутов (в том числе, задавать дополнительные ограничения) можно при помощи стандартного редактора атрибутов класса, используя вкладку Oracle8.

Реляционные таблицы связанные не идентифицирующей связью показаны на рисунке 66.

Рис.66. Реляционные таблицы на диаграмме классов

Для изображенной на рисунке 66 схемы, SQL скрипт имеет следующий вид:

CREATE TABLE HR.COUNTRIES (

COUNTRY_ID CHAR(2),

COUNTRY_NAME VARCHAR2(40),

CONSTRAINT COUNTRY_C_ID_PK PRIMARY KEY (COUNTRY_ID));

таблица COUNTRIES

ограничение первичного ключа

CREATE TABLE HR.LOCATIONS (

LOCATION_ID NUMBER(4,0),

STREET_ADDRESS VARCHAR2(40),

POSTAL_CODE VARCHAR2(12),

CITY VARCHAR2(30) CHECK (CITY <> 'TYMEN'),

STATE_PROVINCE VARCHAR2(25),

COUNTRY_ID CHAR(2),

CONSTRAINT LOC_ID_PK PRIMARY KEY (LOCATION_ID),

CONSTRAINT LOC_C_ID_FK FOREIGN KEY(COUNTRY_ID) REFERENCES HR.COUNTRIES(COUNTRY_ID));

таблица LOCATIONS

ограничение на возможные значения

ограничение первичного ключа

ограничение внешнего ключа

CREATE INDEX HR.LOC_CITY_IX ON HR.LOCATIONS (CITY);

CREATE INDEX HR.LOC_STATE_PROVINCE_IX ON HR.LOCATIONS (STATE_PROVINCE);

CREATE INDEX HR.LOC_COUNTRY_IX ON HR.LOCATIONS (COUNTRY_ID);

индекс

индекс

индекс

Генерация реляционных просмотров (Relational Views)

Реляционные просмотры – стандартный механизм БД Oracle для представления данных из различных реляционных таблиц, объеденных на основе заданной выборки. Пример просмотра, содержащего данные двух реляционных таблиц, приведен на рисунке 67.

Рис.67. Схема БД из двух реляционных таблиц и основанного на них просмотра

Соответствующий реляционному просмотру, изображенному на рисунке 67, SQL скрипт имеет следующий вид:

CREATE OR REPLACE VIEW HR.RV1 (LOCATION_ID, COUNTRY_ID,

COUNTRY_NAME,STATE_PROVINCE,POSTAL_CODE,CITY,

STREET_ADDRESS)

AS SELECT LOCATIONS.LOCATION_ID, LOCATIONS.COUNTRY_ID,

COUNTRIES.COUNTRY_NAME, LOCATIONS.STATE_PROVINCE,

LOCATIONS.POSTAL_CODE, LOCATIONS.CITY,

LOCATIONS.STREET_ADDRESS

FROM HR.LOCATIONS,HR.COUNTRIES

WHERE LOCATION.COUNTRY_ID = COUNTRIES.COUNTRY_ID;

просмотр RV1

параметры выборки

задействованные таблицы и

условие выборки

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]