- •Лабораторная работа № 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 Тема: создание индексов
- •Типы индексов
- •Создание индекса
- •Просмотр индексов
- •Удаление индекса
Создание последовательности
Последовательность для автоматической генерации чисел создается командой CREATE SEQUENCE.
Синтаксис
CREATE SEQUENCE последовательность
[INCREMENT BY n]
[START WITH n]
[{MAXVALUE n | NOMAXVALUE}]
[{MINVAUJE n | NOMINVALUE}]
[{CYCLE | NOCYCLE}]
[{CACHE n | NOCACHE}]
где: |
последовательность |
имя генератора последовательности |
|
INCREMENT BY n |
интервал между двумя последовательными номерами; n является целым числом. Если это предложение опущено, приращение при генерации чисел равно 1. |
|
START WITH n |
первое генерируемое число в последовательности. Если это предложение опущено, последовательность начинается с 1. |
|
MAXVALUE n |
максимальное значение, которое может генерировать последовательность. |
|
NOMAXVALUE |
максимальное значение по умолчанию, равное 1027. |
|
MINVALUE n |
минимальное значение последовательности. |
|
NOMINVALUE |
задает минимальное значение, равное 1. |
|
CYCLE | NOCYCLE |
продолжается ли циклическая генерация чисел после достижения максимального или минимального значения. Значение по умолчанию — NOCYCLE. |
|
CACHE n | NOCACHE |
количество чисел, которые сервер Oracle распределяет предварительно и хранит в памяти. По умолчанию сервер хранит в кэш-памяти 20 значений. |
Пример.
Создание последовательности с именем film_id в таблице film. Первое число последовательности — 51. Кэширование значений и циклическая генерация чисел не заданы.
SQL> CREATE SEQUENCE film_id
2 INCREMENT BY 1
3 START WITH 51
4 MAXVALUE 9999999
Последовательность создана.
He применяйте режим CYCLE, если последовательность используется для генерации первичных ключей.
Проверка параметров последовательности
Созданная вами последовательность документируется в словаре данных. Поскольку последовательность является объектом базы данных, информацию о ней можно найти в таблице словаря данных USER_OBJECTS.
Проверить параметры последовательности можно также путем выборки данных из таблицы словаря данных USER_SEQUENCES.
Пример.
Вывод информации о всех последовательностях, владельцем которых вы являетесь.
SQL> SELECT sequence_name, min_value, max_value,
2 increment_by, last_number
3 FROM user_sequences ;
SEQUENCE_NAME |
MIN_VALUE |
MAX_VALUE |
INCREMENT_BY |
LAST_NUMBER |
------------------------- |
------------------ |
--------------------- |
---------------------- |
-------------------- |
CUSTID |
1 |
9999999 |
1 |
109 |
CUS_SEQ |
1 |
9999999 |
1 |
1 |
FILM_ID |
1 |
9999999 |
1 |
51 |
ORDID |
1 |
9999999 |
1 |
622 |
PRODID |
1 |
9999999 |
1 |
200381 |
PYAT |
1 |
9999999 |
1 |
110 |
SCHETCHIK |
1 |
9999999 |
1 |
41 |
SEQ1 |
1 |
9999999 |
1 |
5 |
STO |
1 |
9999999 |
1 |
2100 |
TRI |
|
|
|
62 |