Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Базы данных Язык SQL.doc
Скачиваний:
2
Добавлен:
01.03.2025
Размер:
1.4 Mб
Скачать

4.2.4 Создание таблиц на основе других таблиц

Можно создать новую таблицу как результат запроса на выборку из одной или более существующих таблиц при помощи команды:

CREATE TABLE имя_таблицы AS запрос_на_выборку

Например, можно создать новую таблицу, являющуюся копией таблицы students:

CREATE TABLE copy_students AS

SELECT * FROM students

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

4.3 Команды манипулирования данными

Команды CREATE TABLE … и ALTER TABLE …никак не влияют на наполнение таблиц данными. Для этих целей используется язык DML (Data Manipulation Language), который позволяет полностью контролировать процессы наполнения таблиц и измения данных.

Основные команды манипулирования данными:

INSERT – добавить данные

DELETE – удалить данные изменяют состояние базы данных

UPDATE – изменить данные

SELECT – выбрать данные без изменения состояния базы данных

Для фиксации изменений, произведенных командами UPDATE, DELETE, INSERT, необходимо выполнить команду фиксации транзакции COMMIT; можно отменить их действие командой ROLLBACK (откат). Подробнее о транзакциях будет рассказано в следующем разделе.

Следует отметить, что при выполнении команд UPDATE, DELETE, INSERT СУБД автоматически проверяет все ограничения, которые были указаны при создании таблиц. Эти проверки, безусловно, существенно замедляют выполнение данных команд. Дополнительное время и другие ресурсы затрачиваются на обеспечение возможности отмены команды (отката). Однако все эти затраты окупаются гарантией того, что правила целостности данных, заложенные в команды DDL, ни при каких обстоятельствах не могут быть нарушены.

4.3.1 Команда insert

Вариант 1 – вставка одной строки

Команда имеет вид:

Insert into имя_таблицы [(список_имен_столбцов)]

Values (список значений)

Если в команде список имен столбцов опущен, то будут последовательно заполнены все столбцы в том порядке, в котором они были указаны в команде CREATE TABLE.

Например:

INSERT INTO subjects VALUES (5, ‘Базы данных’)

INSERT INTO students (cod_st, name_st, born) VALUES (3, ‘Петров’,’12.03.1990’)

Во второй команде столбец phone (телефон) таблицы students можно оставить незаполненным, т.к. на него не наложено ограничение NOT NULL.

Рассмотрим, при каких ситуациях данные команды могут привести к ошибке. В случае вставки нового предмета таких ситуаций две – уже есть предмет либо с кодом 5, либо с названием Базы данных (оба столбца предполагают проверку уникальности). Во втором случае на уникальность будет проверен только один столбец cod_st.

Команда

INSERT INTO subjects(cod_st, cod_sub, mark) VALUES (3, 5, 1)

в нашей демонстрационной базе данных не имеет никаких шансов выполниться, поскольку на столбец mark наложено ограничение

CHECK (mark BETWEEN 2 AND 5)

Исправим оценку:

INSERT INTO subjects(cod_st, cod_sub, mark) VALUES (3, 5, 4)

Мы уже знаем, что предмет с кодом 5 существует, как и студент с кодом 3, значит, ограничения внешнего ключа не нарушены. Однако может случиться последняя из возможных исключительных ситуаций – нарушение уникальности составного первичного ключа таблицы mark (студент с кодом 3 уже имеет оценку по предмету с кодом 5). В случае, если уникальность не нарушена, новая строка благополучно добавится в таблицу marks.

Вариант 2 – вставка множества строк на основе запроса по другим таблицам

Команда имет вид: