Структурированный язык запросов SQL. Операции изменения и обнов­ления базы данных

Обратим внимание на предложения обновления данных UPDATE (обновить), DELETE (удалить) и INSERT (вставить).

Предложение UPDATE.

 

Предложение UPDATE имеет следующий общий формат:

UPDATE таблица

SET поле = выражение

[,поле = выражение] ...

[WHERE предикат];


Все записи в "таблице", которые удовлетворяют "предикату", обновляются в соответствии с присваиваниями "поле = выражение" во фразе SET (установить).

ОБНОВЛЕНИЕ ЕДИНСТВЕННОЙ ЗАПИСИ


Изменить фамилию поставщика 2 на Сандерс и город на 'Берлин':

UPDATE Поставщики

SET Фамилия = 'Сандерс', Город = 'Берлин'

WHERE Номер_Поставщика = 2;

Для каждой записи, которая должна быть обновлена (т. е. для каждой записи, которая удовлетворяет предикату WHERE, или для всех записей, если фраза WHERE опущена), ссылки во фразе SET на поля этой записи обозначают значения этих полей перед тем, как будет выполнено какое-либо присваивание в этой фразе SET.

ОБНОВЛЕНИЕ МНОЖЕСТВА ЗАПИСЕЙ


Удвоить вес всех деталей, производимых в Лондоне.

UPDATE Детали

SET Вес = 2*Вес

WHERE Город = 'Лондон';

 

ОБНОВЛЕНИЕ С ПОДЗАПРОСОМ


Установить вес деталей равным 10 для всех поставщиков из Лондона.

UPDATE Детали

SET Вес = 10

WHERE 'Лондон' =

(SELECT Город

FROM Поставщики

WHERE Поставщики.НОМЕР_ПОСТАВЩИКА = Детали.НОМЕР_ПОСТАВЩИКА);

 

ОБНОВЛЕНИЕ НЕСКОЛЬКИХ ТАБЛИЦ


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

ПРЕДЛОЖЕНИЕ COMMIT ИЛИ ROLLBACK


Необходимо сначала дать определение транзакции.
Транзакция - это неразрывная последовательность действий, составленная из одного или нескольких предложений SQL. Любая транзакция оканчивается предложением COMMIT или ROLLBACK.

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

  1. исполнится предложение COMMIT (фиксировать), которая все предварительные обновления сделает окончательными (зафиксирует);
  2. исполнится предложение ROLLBACK (откат), которая аннулирует сделанные вами изменения в базе данных.

 

UPDATE Детали

SET ЦВЕТ = 'Желтый'

WHERE НОМЕР_Поставщика = 3;

COMMIT

 

Предложение DELETE.

 

Предложение DELETE имеет следующий общий формат:

DELETE

FROM таблица

[WHERE Условие];


Удаляются все записи в "таблице", которые удовлетворяют "условию".

УДАЛЕНИЕ ЕДИНСТВЕННОЙ ЗАПИСИ


Удалить поставщика с фамилией Адамс:

DELETE

FROM Поставщики

WHERE Фамилия = 'Адамс';


И снова, если таблица Детали в настоящее время содержит какие-либо поставки для поставщика Адамса, это удаление нарушит непротиворечивость базы данных; как и в случае предложения UPDATE, нет операций DELETE, воздействующих на несколько таблиц.

УДАЛЕНИЕ МНОЖЕСТВА ЗАПИСЕЙ


Удалить всех поставщиков из Лондона.

DELETE

FROM Поставщики

WHERE Город = 'Лондон';


Поставщики - все еще известная таблица, но она теперь пуста. Удалить все записи - это не уничтожить таблицу (операция DROP).

УДАЛЕНИЕ С ПОДЗАПРОСОМ


Удалить все детали из Лондона для поставщиков.

DELETE

FROM Детали

WHERE 'Лондон' =

(SELECT Город

FROM Поставщики

WHERE Поставщики.Номер_Поставщика = Детали.Номер_Поставщика);

 

Предложение INSERT.

 

Предложение INSERT имеет следующий общий формат:

INSERT

INTO таблица [(поле [,поле] . . .)]

VALUES (константа [,константа] ...);

или

INSERT

INTO таблица [(поле [,поле] . . .)]

подзапрос;


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