- •Лабораторная работа № 1 Тема: создание таблиц
- •Ссылка на таблицы других пользователей
- •Параметр default
- •Правила присвоения имен
- •Типы данных в Oracle
- •Ограничения
- •Ограничения целостности данных
- •Ограничение not null
- •Ограничение unique
- •Ограничение primary key
- •Ограничение foreign key
- •Ограничение check
- •Пример. Создание таблицы базы данных Film, Klient, Dogovor.
- •6 Regiser varchar2(20), Таблица создана.
- •Создание таблицы с заполнением строками из другой таблицы
- •Лабораторная работа №2
- •2 Values (1, 'Красотка', 'Поланский','12-12-1987', 30, 2);
- •1 Строка создана.
- •1 Строка создана. Копирование строк из другой таблицы
- •Insert into таблица (столбец[, столбец]}
- •3 Строки создано.
- •Обновление строк
- •1 Строка обновлена.
- •Команды явного управления транзакциями
- •Оператор конкатенации
- •Строки символов (литералы)
- •Обработка неопределенных значений
- •Функция nvl
- •Синтаксис
- •7 Строк выбрано. Преобразование nvl для различных типов
- •Лабораторная работа №4 Тема: ограничение количества выбираемых строк.
- •Азазель 40 5
- •7 Строк выбрано.
- •1 Иванов и.Н. 005363
- •Пример. Вывод названия фильмов и стоимости проката для фильмов, количество которых 3 и 5.
- •Сочетание символов в искомой строке
- •Строки не выбраны
- •2 From film 3 Азазель
- •Пример. Вывод кодов фильмов и их названий, имеющих режиссера.
- •Порядок выполнения операций Правила приоритета
- •1 Красотка 42 3
- •Пример.
- •Пример.
- •Числовые функции
- •Пример.
- •Использование арифметических операторов с датами
- •Арифметические операторы над датами
- •Функции для работы с датами
- •Пример.
- •Функции преобразования
- •Вывод даты в заданном формате
- •Форматы времени
- •Пример.
- •Элементы формата числа
- •Пример.
- •Лабораторная работа №7 Тема: групповые функции Групповые функции
- •Групповые функции
- •Пример. Вывод первого и последнего названия фильма из алфавитного списка всех фильмов.
- •8 Строк выбрано.
- •Предложение having
- •Пример.
- •Лабораторная работа №8 Тема: подзапросы
- •From таблица
- •(Select список_выбора
- •Однострочные подзапросы
- •Многострочные подзапросы
- •Лабораторная работа №9 Тема определение переменных во время выполнения Переменные подстановки с одним амперсантом
- •Команда set verify
- •Определение текстовых строк и дат с помощью переменных подстановки
- •Указание имен столбцов, выражений и текстовых строк во время выполнения
- •Определение переменных пользователя
- •Лабораторная работа №10 Тема: изменение таблиц и ограничений Добавление столбца
- •Изменение столбца
- •Добавление и удаление ограничений
- •Разрешение и запрет ограничений
- •Удаление таблицы
- •Команда rename:
- •Команда truncate: Синтаксис
- •Усечение таблицы.
- •Добавление комментариев к таблице
- •Лабораторная работа №11 Тема: создание последовательности
- •Создание последовательности
- •Проверка параметров последовательности
- •10 Строк выбрано. Псевдостолбцы nextval и currval
- •Пропуски в последовательности
- •Просмотр следующего свободного значения без его увеличения
- •Изменение параметров последовательности
- •Лабораторная работа № 12. Тема: словарь данных.
- •Запросы к словарю данных
- •Классы представлений
- •Прочие представления
- •Лабораторная работа № 13. Тема: создание представлений
- •2 As select filmId, namef, god_vip Дата_выпуска
- •13 Куклы 13.05.99
- •2 (Номер, Название, Дата)
- •2 (ИмяКлиента, посл_Выдача, Перв_выдача)
- •2 (Номер, Название, Дата)
- •Удаление представления
- •Лабораторная работа №14 Тема: создание индексов
- •Типы индексов
- •Создание индекса
- •Просмотр индексов
- •Удаление индекса
Лабораторная работа № 13. Тема: создание представлений
Представление — это логическая таблица, созданная на основе реальной таблицы или другого представления. Представление не содержит собственных данных, а скорее является "окном", через которое можно просматривать или изменять данные из таблиц. Представление хранится в словаре данных как команда SELECT. Использование представлений позволяет осуществлять выборку данных из нескольких таблиц без каких-либо знаний об операторе соединения таблиц (join).
Представление создается путем включения подзапроса в команду CREATE VIEW.
Синтаксис
CREATE [OR REPLACE] [FORCE | NOFORCE] VIEW представление
[(псевдоним[, псевдоним}...)]
AS подзапрос
[WITH CHECK OPTION [CONSTRAINT ограничение]]
[WITH READ ONLY]
где: FORCE |
создание представления независимо от того, существуют ли базовые таблицы. |
NOFORCE |
создание представления только при условии существования базовых таблиц. Это значение принято по умолчанию. |
представление |
имя представления. |
псевдоним |
имена выражении, выбранных в запросе для представления. Количество псевдонимов должно быть равным количеству выражений, выбранных представлением. |
подзапрос |
полная команда SELECT. Для столбцов в списке SELECT можно использовать псевдонимы. |
WITH CHECK OPTION |
режим, при котором добавлять или обновлять можно только строки, доступные в представлении. |
ограничение |
имя, присвоенное ограничению CHECK OPTION. |
WITH READ ONLY |
запрет применения к данному представлению операций DML. |
Запрос, который определяет представление, может содержать команду SELECT со сложным синтаксисом, включая соединения, группы и подзапросы.
Запрос, который определяет представление, не может содержать предложение ORDER BY.
Если вы не указываете имя ограничения сами, система присвоит его по умолчанию в формате SYS_Cn.
Для изменения определения представления без его удаления и создания заново, а также для изменения предоставленных привилегий можно использовать режим OR REPLACE.
Существуют два вида представлений: простые и сложные. Основное отличие связано с операциями DML.
Пример.
Создание представления, которое включает номер фильмов и дату выпуска всех фильмов после 01.01.1989 года. Включить псевдоним столбца god_vip в подзапрос. Вывод содержимого на экран.
SQL> Create view films
2 As select filmId, namef, god_vip Дата_выпуска
3 from film
4 where god_vip > '01.01.1989';
Представление создано.
SQL> select * from films;
FILMID NAMEF ДАТА_ВЫП
---------- ------------------------- ---------------------
2 Дом 17.01.91
…
13 Куклы 13.05.99
Пример.
Изменение представления films. Присвойте столбцу с номером фильма заголовок Номер, столбцу с название фильма – Название, а столбцу с годом выпуска - заголовок Дата.
SQL> Create or replace view films