Oracle - технологии создания распределенных информационных систем
ОПЕРАТОРЫ МАНИПУЛИРОВАНИЯ ДАННЫМИ.
Среди операторов SQL данного класса мы подробно рассмотрим только четыре основных оператора: INSERT - ВСТАВКА ДАННЫХ, SELECT - ВЫБОРКА ДАННЫХ, DELETE - УДАЛЕНИЕ ДАННЫХ, UPDATE - ИЗМЕНЕНИЕ ДАННЫХ.
INSERT
Вставить строки в таблицу или в базовую таблицу представления.
ОТСЮДА
img src="oracle_pr52.gif" border=0 WIDTH=500 HEIGHT=145>
Пример: В качестве примера рассмотрим вставку даннух в таблицу "Праздничные дни" (PRAZDNIKI)
insert into prazdniki values ('понедельник'); insert into prazdniki values ('вторник'); insert into prazdniki values ('среда'); insert into prazdniki values ('четверг'); insert into prazdniki values ('пятница'); insert into prazdniki values ('суббота'); insert into prazdniki values ('воскресенье');
SELECT
Выбирает данные из одной или нескольких таблиц или представлений. Может использоваться как оператор или как подзапрос в другом операторе.
img src="oracle_pr53.gif" border=0 WIDTH=500 HEIGHT=82>
img src="oracle_pr54.gif" border=0 WIDTH=500 HEIGHT=132>
img src="oracle_pr55.gif" border=0 WIDTH=500 HEIGHT=134>
img src="oracle_pr56.gif" border=0 WIDTH=500 HEIGHT=155>
Select_list::=
table_list::=
update_list::=
Пример 1: Лучшим примером, иллюстрирующим работу оператора SELECT, является юмористический пример "Как программист SQL охотится на слонов". Дано: Слон живет в Африке. Задача: Что надо сделать чтобы найти слона? Метод решения: Программист SQL делает SELECT.
SELECT "СЛОН" FROM AFRICA; Итог: Все африканские слоны найдены.
Проиллюстрируем использование оператора SELECT на нескольких примерах.
Пример 2: Показать всех врачей заведенных в БД (см. рис.10).
SELECT * FROM doctors ORDER BY dc_name;
Результат: все записи из таблицы DOCTORS отсортированные по полю dc_name по алфавиту.
Пример 3. Показать всех врачей с кодом специальности равным 111.
SELECT dc_name FROM doctors WHERE dc_speciality_nnn = 111 ORDER BY dc_name;
Пример 4. Показать всех врачей с кодом специальности равным 111 или 112.
SELECT dc_name FROM doctors WHERE dc_speciality_nnn = 111 OR dc_speciality_nnn = 112 ORDER BY dc_name;
2-ой способ
SELECT dc_name FROM doctors WHERE dc_speciality_nnn in (111, 112) ORDER BY dc_name;
Операции над множествами в операторах SELECT
Операция |
Выполняемые функции |
UNION |
Комбинирует два запроса; возвращает все неповторяющиеся строки, извлеченные хотя бы одним из запросов. |
UNION ALL |
Комбинирует два запроса; возвращает все строки, извлеченные хотя бы одним из запросов, вклячая повторяющиеся. |
INTERSECT |
Комбинирует два запроса; возвращает все неповторяющиеся строки, извлеченные каждым из запросов. |
MINUS |
Комбинирует два запроса; возвращает все неповторяющиеся строки, извлеченные первым запросом, но не извлеченные вторым. |
Операция |
Выполняемые функции |
(+) |
Указывает, что предшествующий столбец является столбцом внешнего соединения. |
* |
Используется вместо имен столбцов при выборке всех столбцов из таблицы или представления. |
PRIOR |
Используется в иерархическом древовидном запросе для определения зависимости между родительскими и дочерними строками. Смотрити оператор SELECT. |
ALL |
Оставляет повторяющиеся строки в результате запроса (установлен по умолчанию ALL, но не DISTINCT). |
DISTINCT |
Удаляет повторяющиеся строки из результата запроса. |
Пример 5. Показать всех врачей с кодом специальности равным 111 и работающих в подразделении №2.
SELECT dc_name FROM doctors WHERE dc_speciality_nnn = 111 AND dc_shtat_nnn = 2 ORDER BY dc_name; Пример 6. Показать всех пациентов врача Иванова А. А. SELECT pt.pt_name FROM patients pt ,doctors dc WHERE dc.dc_nnn = pt.pt_dc_nnn AND dc.dc_name = 'ИВАНОВ А. А.' ORDER BY pt.pt_name;
На этом примере остановимся подробнее: Первое - здесь впервые появились в запросе псевдонимы таблиц (pt, dc), это очень важный элемент , так как может оказаться, что по нерадивости у Вас в обоих таблицах имеются одинаковые наименования столбцов и тогда для обращения к ним потребуется использование псевдонимов таблиц. Второе - Делая запрос к нескольким таблицам необходимо использовать джойны (dc.dc_nnn = pt.pt_nnn), т.е. явно задавать те поля, которые определяют отношения между таблицами, причем чесло джойнов равняется N-1, где N - число таблиц в запросе. Третье - выборка данных по условию dc.dc_name = 'ИВАНОВ А. А.' накладывает очень жесткие требования на правильность ввода данных (они могут быть набиты маленькими буквами, через несколько пробелов и т.п.), не учет этих особенностей приведет к тому, что некоторая нужная информация не будет выбрана. Чтобы избежать этого лучше в условиях использовать числовые поля, например личный номер врача (если он имеется БД).О принципах написание SELECT можно написать несколько томов, мы здесь изложили только несколько, с нашей точки зрения, важных особенностей, более подробную информацию по синтаксису можно всегда найти в справочной литературе.
DELETE
Удаляет строки из таблицы или из базовой таблицы представления, удовлетворяющие условию WHERE. Удаляет все строки, если условие WHERE не задано.
Пример:
Удаляем все записи из таблицы Праздничных дней.delete from prazdniki;
UPDATE
Изменяет существующие значения в таблице или в представлении (View).
Операции над объектами базы данных.
DROP
Эта команда удаляет объекты и ограничения из базы данных. Для этого действия требуются соответствующие привилегии. Например, для удаления общего канала связи базы данных требуется привилегия
DROP PUBLIC DATABASE LINK.
cluster_clause::=
contects_clause::=
EXPLAIN PLAN
Описывает каждый шаг плана выполнения оператора SQL и помещает (если задано) это описание в указанную таблицу
ROLLBACK (управление транзакцией)
Отменяет все изменения, сделанные до контрольной точки. Отменяет все изменения, произведенные в текущей транзакции, если контрольная точка не задана.
Команды управления привилегиями и ролями
REVOKE (системные привилегии и роли )
Отменяет системные привилегии и роли, ранее предоставленные пользователям и ролям. Действие, обратное команде GRANT (системные привилегии и роли ) .
REVOKE (привилегии доступа к объектам)
Отменяет привилегии доступа к определенному объекту, ранее предоставленные пользователям и ролям. Действие, обратное команде GRANT (привилегии доступа к объектам). CREATE ROLEСоздает роль.
SET ROLE (управление сеансом)
Разрешает заданную роль в текущем сеансе и запрещает псе другие роли пользователя. Должна выполняться в начале транзакции вместе с оператором SET TRANSACTION.
GRANT (системные привилегии и роли)
Предоставляет системные привилегии пользователям и ролям. Предоставляет роли пользователям и другим ролям.
GRANT (привилегии доступа к объектам)
Предоставляет привилегии доступа к определенным объектам (таблицам, представлениям, синонимам, пакетам, процедурам и т.д.) пользователям и ролям.