Создание других объектов схемы

Помимо таблиц, другими важными объектами схемы являются представления, последовательности, индексы и синонимы. Представление - это логическая или виртуальная таблица. Синонимы - это просто псевдонимы для объектов базы данных. Синонимы также упрощают написание запросов и обеспечивают элемент безопасности системы, маскируя фактическое имя объекта базы данных. Последовательности - это специальные объекты базы данных, которые поддерживают автоматическое создание целочисленных значений и часто используются для генерировать значения первичных ключей для таблиц. Индексы создаются для столбцов таблицы, чтобы облегчить быстрый поиск информации из таблиц.

Просмотры

Представление базы данных - это логическая или виртуальная таблица, основанная на запросе. Представления запрашиваются так же, как и таблицы. Это означает, что с вашей точки зрения как разработчика или с точки зрения пользователя системы баз данных представление выглядит как таблица. Определение представления поскольку объект хранится в словаре данных базы данных; однако само представление не хранит никаких данных. База данных также хранит план выполнения для создания представления - это означает, что данные могут быть быстро извлечены с помощью представления, даже если фактические данные, представленные запросом SELECT представления, не сохраняются как часть представления. Скорее, данные «собираются вместе» каждый раз, когда представление запрашивается из таблиц базы данных, для которых определено представление - они называются базовыми таблицами.

Общий синтаксис приведен ниже.

CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW [ViewName]
[(Column Alias Name...)] 
AS [Query]
[WITH [CHECK OPTION] [READ ONLY] [CONSTRAINT]];

Из синтаксиса

Параметр FORCE позволяет создать представление, даже если базовая таблица, на которую оно ссылается, еще не существует. Этот параметр используется для создания представления до фактического создания базовых таблиц и сопутствующих данных.

Параметр NOFORCE является противоположностью FORCE и позволяет пользователю системы создать представление, если у них есть необходимые привилегии для создания представления и если таблицы, из которых создается представление, уже существуют. Это вариант по умолчанию.

Параметр WITH READ ONLY позволяет создавать представление, доступное только для чтения. Вы не можете использовать команды DELETE, INSERT или UPDATE для изменения данных для представления только для чтения.

Предложение WITH CHECK OPTION позволяет обновлять строки, которые можно выбрать в представлении. Оно также позволяет указывать ограничения для значений. Предложение CONSTRAINT работает вместе с предложением WITH CHECK OPTION, чтобы администратор базы данных мог назначить уникальное имя. к ОПЦИИ ПРОВЕРКИ. Если администратор базы данных опускает предложение CONSTRAINT, Oracle автоматически присваивает ограничению сгенерированное системой имя, которое не будет иметь большого смысла.

Типы просмотров

Простое представление создается только поверх одной таблицы. Это простой запрос SELECT без функций или предложения группы, а только выбор столбцов из таблицы без какого-либо преобразования. Если DML выполняется для представления, он сразу же отражается в базовой таблице.

Сложное представление создается для нескольких таблиц с помощью объединений. Оно может содержать функции SQL, группировать по функциям. Но поскольку представление находится на нескольких данных и выбор столбцов также не прост, он не позволяет выполнять операции DML с ним.

Иллюстрация

Simple View: В приведенном ниже простом представлении выберите имя сотрудника, идентификатор отдела и зарплату для сотрудников с идентификатором JOB ID как DEV.

CREATE OR REPLACE VIEW v_emp_dev
AS
SELECT first_name, department_id, salary
FROM employees
WHERE job_id = 'DEV';

Complex view: В приведенном ниже примере показано название отдела, средняя заработная плата в отделе и количество сотрудников, работающих в нем.

CREATE OR REPLACE VIEW EMP_VU
AS
SELECT department_name, AVG (salary) avg_sal, COUNT (first_name) count
FROM employees E, departments D
WHERE E.department_id = D.department_id
GROUP BY department_name;

DESCRIBE [view name]описывает структуру представления. Столбцы перечислены в той же последовательности, что и в определении представления.

Операции DML в представлении

Операции DML можно легко выполнять на простых представлениях. Как было сказано ранее, операции вставки, обновления и удаления фактически выполняются в базовой таблице.

Когда вы выполняете оператор UPDATE, DELETE или INSERT DML для представления, вы фактически управляете строками данных для базовой таблицы или таблиц, в которых определено представление. Существуют ограничения на использование операторов UPDATE, DELETE и INSERT с представлениями. Во-первых, чтобы использовать оператор UPDATE, DELETE или INSERT с представлением, представление должно быть обновляемым. Представление может обновляться, если предложение SELECT не указывает какую-либо агрегатную функцию в списке SELECT. Кроме того, представление не может были созданы с помощью предложения или предложений GROUP BY, DISTINCT или UNION. Допускается использование агрегатных функций в подзапросе SELECT в предложении FROM. Кроме того, представление не может иметь производных столбцов в списке SELECT. Затем, если представление создается в результате операции JOIN (представление соединения), операторы UPDATE и INSERT могут изменять или вставлять строки только в одну из базовых таблиц за раз. Вы не можете изменять строки из двух или более таблиц с помощью одного оператора языка обработки данных (DML). Наконец, оператор DELETE может выполняться только для представления, если на таблицу имеется ссылка в предложении FROM. Это просто означает, что вы не можете удалять строки из таблицы, которая не была указана.

Предложение WITH CHECK OPTION

WITH CHECK OPTION - это необязательное предложение, которое определяет уровень проверки, которая должна выполняться при вставке или обновлении данных через представление. Если представление создано с использованием предложения WITH CHECK OPTION, каждая строка, которая вставляется или обновляется в базовой таблице через представление должен соответствовать определению вида. Обратите внимание, что этот параметр нельзя указать, если представление создано только для чтения.

Например, представление V_EMP_DEV создается для сотрудников, которые являются разработчиками (JOB_ID = DEV).

CREATE OR REPLACE VIEW v_emp_dev
AS
SELECT first_name, department_id, salary, 
FROM employees
WHERE job_id = 'DEV'
WITH CHECK OPTION empvu_dev;

Пользователь пытается обновить зарплату сотрудника отдела кадров через представление, но обнаруживает исключение. Это потому, что представление было создано С ОПЦИЕЙ ПРОВЕРКИ.

UPDATE v_emp_dev
SET salary = salary+500
WHERE JOB_ID = 'HR';
ORA-01402: view WITH CHECK OPTION where-clause violation

Если бы это было простое представление, оператор UPDATE не вызвал бы никаких исключений.

Прекращение просмотра

Администратор базы данных (DBA) или владелец представления может удалить представление с помощью оператора DROP VIEW. Если представление имеет определенные ограничения, тогда вам необходимо указать предложение CASCADE CONSTRAINTS при удалении представления; в противном случае оператор DROP VIEW не сможет обработать. Если другое представление или другой объект базы данных, такой как синоним или материализованное представление (оба эти объекта обсуждаются позже в этой главе), ссылается на отброшенное представление, Oracle не удаляет эти объекты базы данных; вместо этого Oracle отмечает их как недопустимые. Вы можете отбросить эти недопустимые объекты или переопределить их, чтобы снова сделать их действительными.

Приведенная ниже команда DROP VIEW удаляет представление EMP_VU из базы данных.

DROP VIEW EMP_VU;

Последовательности

Oracle предоставляет возможность генерировать последовательности уникальных чисел для этого типа использования, и они называются последовательностями. Как правило, последовательности используются для генерации уникальных последовательных целочисленных значений, которые используются в качестве значений первичных ключей в таблицах базы данных. быть сгенерировано в возрастающем или убывающем порядке. Обратите внимание, что число, однажды созданное последовательностью, не может быть отменено.

Синтаксис

CREATE SEQUENCE <sequence name>
[INCREMENT BY < number >]
[START WITH < start value number>]
[MAXVALUE < MAXIMUM VLAUE NUMBER>]
[NOMAXVALUE]
[MINVALUE < minimum value number>]
[CYCLE | NOCYCLE]
[CACHE < number of sequence value to cache> | NOCACHE]
[ORDER | NOORDER];

Из синтаксиса

Оператор CREATE SEQUENCE должен указывать уникальное имя последовательности. Это единственное обязательное условие в заявлении. Если вы не укажете какие-либо другие пункты, все сгенерированные порядковые номера будут соответствовать настройкам Oracle по умолчанию.

Предложение INCREMENT BY определяет, как увеличивается последовательность при генерации каждого числа. По умолчанию приращение равно единице; однако, если у вас есть веская причина для пропуска чисел в последовательности, вы можете указать другое приращение. Положительное числовое приращение генерирует возрастающие порядковые номера с интервалом, равным выбранному вами интервалу. Отрицательное числовое приращение генерирует убывающие порядковые номера.

Предложение START WITH указывает начальное числовое значение для последовательности - начальный номер по умолчанию - 1. Кроме того, вы должны указать начальное значение, если у вас уже есть строки с данными в столбце, которые теперь будут хранить значения последовательности.

Предложение MAXVALUE определяет максимальное значение, до которого может быть увеличена последовательность. В отсутствие MAXVALUE максимально допустимое значение, которое может быть сгенерировано для последовательности, довольно велико, 10 в 27-й степени - 1. Значение по умолчанию - NOMAXVALUE.

Предложение MINVALUE определяет минимальное значение последовательности для убывающей последовательности (той, которая генерирует числа в порядке убывания). По умолчанию - НОМИНАЛЬНОЕ ЗНАЧЕНИЕ.

Предложение CYCLE указывает, что значения последовательности можно повторно использовать, если последовательность достигает указанного MAXVALUE. Если последовательность циклов повторяется, числа генерируются снова, начиная со значения НАЧАТЬ С.

Предложение CACHE может улучшить производительность системы, позволяя Oracle генерировать указанный пакет упорядоченных чисел для хранения в кэш-памяти.

Если вы укажете CACHE без указания номера, размер кэша по умолчанию составляет 20 порядковых номеров. При желании вы можете указать NOCACHE, чтобы предотвратить кеширование порядковых номеров.

Предложение ORDER указывает, что порядковые номера выделяются в точном хронологическом порядке, в котором они запрашиваются.

NEXTVAL и CURRVAL

Значения последовательности генерируются с помощью двух псевдостолбцов с именами currval и nextval. Псевдостолбец ведет себя как столбец таблицы, но псевдостолбцы фактически не хранятся в таблице. При первом выборе псевдостолбца nextval начальное значение в последовательность возвращается. Последующие выборки псевдостолбца nextval заставляют последовательность увеличиваться, как указано в предложении INCREMENT BY, и возвращать вновь созданное значение последовательности. Псевдостолбец currval возвращает текущее значение последовательности, которое является значением, возвращаемым последняя ссылка на nextval.

В сеансе первым действием в последовательности должно быть NEXTVAL, а не CURRVAL. Это связано с тем, что в сеансе, когда NEXTVAL генерирует первый номер сеанса из последовательности, Oracle сохраняет текущее значение в CURRVAL.

Синтаксис:

Sequence.NEXTVAL
Sequence.CURRVAL

На заметку -

  • CURRVAL и NEXTVAL могут использоваться только во внешнем SQL оператора select.

  • CURRVAL и NEXTVAL могут использоваться в операторе INSERT для замены первичного ключа столбца. Его можно использовать как в качестве предложения подзапроса, так и в предложении VALUES.

  • CURRVAL и NEXTVAL можно использовать для обновления значений в таблицах.

  • CURRVAL и NEXTVAL не могут быть в списке выбора VIEW с ключевым словом DISTINCT, с предложениями GROUP BY, HAVING или ORDER BY и выражением DEFAULT в операторе CREATE TABLE или ALTER TABLE.

Изменение последовательности

Владелец последовательности может изменять последовательность только для изменения атрибутов, таких как INCREMENT BY value, MINVALUE, MAXVALUE, CYCLE или CACHE. Обратите внимание, что сделанные изменения будут отражены в следующих числах.

Синтаксис:

ALTER SEQUENCE [sequence name]
INCREMENT BY n
MAXVALUE n
NOCACHE
NOCYCLE

Удаление последовательности

Команда DROP SEQUENCE удаляет последовательности, которые необходимо воссоздать или которые больше не нужны.

DROP SEQUENCE [sequence name]

Индексы

Индексы - это объекты базы данных, которые используются для настройки производительности запроса SELECT. Существуют различные типы индексов, в том числе те, которые используются для обеспечения соблюдения ограничений первичного ключа, уникальных индексов, неуникальных индексов и конкатенированных индексов, среди прочего. запросы потребовали бы, чтобы Oracle сканировал все строки в таблице, чтобы вернуть необходимые строки для таблицы результатов. Для столбцов таблицы создается индекс, который затем сохраняет все значения столбца в сегменте индекса. В отличие от последовательности, индексы являются таблицами Они автоматически удаляются после удаления таблицы.

Индексы могут создаваться автоматически или вручную. Когда вы указываете ограничение PRIMARY KEY или UNIQUE, Oracle автоматически создает уникальный индекс для поддержки быстрого извлечения данных для указанной таблицы.

В качестве альтернативы пользователь может создавать индексы вручную для оптимизации производительности запросов. Индексы, созданные вручную, могут быть уникальными или неуникальными. Неуникальные индексы могут быть индексами на основе B-дерева, Bitmap или функций. По умолчанию Oracle создает индексы B-Tree для столбцов. . Вот синтаксис

Синтаксис

CREATE [UNIQUE][BITMAP]INDEX index
ON table (column [, column]...);

Обратите внимание, что UNIQUE и BITMAP должны быть указаны только для уникальных индексов и индексов растровых изображений. По умолчанию Oracle создает индексы B-Tree для обычных индексов.

Составной индекс (также называемый конкатенированным индексом) - это индекс, созданный для нескольких столбцов таблицы. Столбцы в составном индексе могут появляться в любом порядке и не обязательно должны быть смежными столбцами в таблице. Составные индексы повышают скорость извлечения строк для запросов, в которых предложение WHERE ссылается на все или ведущую часть столбцов в составном индексе. Индекс может содержать максимум 32 столбца.

Например, пользователь создает индекс IDX_EMP в столбце HIRE_DATE таблицы EMPLOYEES. Использование индекса уменьшит дисковый ввод-вывод за счет обхода сканирования индексированного пути и поиска данных, которые фильтруются в столбце HIRE_DATE.

CREATE INDEX IDX_EMP ON employees(hire_date);

Удаление индекса

Индексы не могут быть изменены, но могут быть изменены для анализа, восстановления или вычисления статистики. Если необходимо изменить определение индекса, его нужно отбросить и создать заново. Синтаксис команды DROP INDEX прост.

DROP INDEX index_name;

Синонимы

Синоним - это псевдоним, то есть форма сокращения, используемая для упрощения задачи ссылки на объект базы данных. Концепция аналогична использованию псевдонимов для друзей и знакомых. Для ссылки на объект, принадлежащий другому пользователю, необходимо указать имя схемы. иметь префикс. С помощью синонима вы уменьшаете необходимость ссылаться на объект вместе с именем схемы. Таким образом, синоним обеспечивает прозрачность местоположения, поскольку имя синонима скрывает фактическое имя объекта и его владельца.

Существует две категории синонимов: общедоступные и частные. Общедоступный синоним может использоваться для обеспечения легкого доступа к объекту для всех пользователей системы. Фактически, лицо, создающее общедоступный синоним, не владеет этим синонимом - скорее, оно будет принадлежать к ПУБЛИЧНОЙ группе пользователей, существующей в Oracle. Частные синонимы, с другой стороны, принадлежат системному пользователю, который их создает, и находятся в нем. схема пользователя.

Синтаксис

CREATE [PUBLIC] SYNONYM [synonym name] 
FOR OBJECT;

Системный пользователь может предоставить право на использование личных синонимов, которыми он владеет, другим пользователям системы. Для создания синонимов необходимо иметь право CREATE SYNONYM. Кроме того, вы должны иметь право CREATE PUBLIC SYNONYM, чтобы создавать общедоступные синонимы. .Если синоним объявлен как общедоступный, имя синонима не может уже использоваться в качестве общедоступного синонима. Попытка создать уже существующий общедоступный синоним приведет к сбою команды CREATE PUBLIC SYNONYM, и Oracle вернет ORA-00955: имя уже используется существующим сообщением об ошибке объекта.

Иллюстрация

Предположим, два пользователя U1 и U2.U1 имеют доступ к таблице EMPLOYEES. Таким образом, чтобы разрешить доступ к таблице EMPLOYEES и к U2, можно создать синоним в схеме U2. Доступ должен быть предоставлен от U1 до U2.

CONN U2/U2
SQL> CREATE SYNONYM EMP_SYN	FOR U1.employees;

CONN U1/U1
SQL> GRANT ALL ON EMP_SYN TO U2;

CONN U2/U2
SQL> SELECT * FROM EMP_SYN;

Удаление синонима

Пользователь может отказаться от синонима, которым он владеет. Чтобы удалить общедоступный синоним, у вас должна быть привилегия DROP PUBLIC SYNONYM.

DROP SYNONYM EMP_SYN;