|
|||
Удаление записейДля удаления записей из таблицы применяется оператор DELETE (удалить):
DELETE FROM имяТаблицы WHERE условие;
Данный оператор удаляет из указанной таблицы записи (а не отдельные значения столбцов), которые удовлетворяют указанному условию. Условие — это логическое выражение, различные конструкции которого были рассмотрены ранее. Следующий запрос удаляет записи из таблицы клиенты, в которой значение столбца Имя равно 'иванов '.
DELETE FROM Клиенты WHERE Имя = 'Иванов';
Если таблица клиенты содержит несколько записей, в которых есть клиент Иванов, то все они будут удалены. В операторе WHERE может находиться подзапрос на выборку данных (оператор SELECT). Подзапросы в операторе DELETE работают точно так же, как и в операторе SELECT. Пусть в базе данных имеется таблица продажи (ID_товара, сумма_заказа, ID_клиента), содержащая сведения о продажах товаров клиентам. Требуется удалить из этой таблицы записи о тех клиентах, которые приобрели товары на сумму, меньшую 1000. Для этого можно использовать такой запрос:
DELETE FROM Продажи Т1 WHERE 1000 > = (SELECT SUM(T2. Суммазаказа) FROM Продажи Т2 WHERE TI. ID_клиента = T2. ID_клиента);
Здесь запрос на удаление записей из таблицы продажи содержит связанный (коррелированный) подзапрос, вычисляющий сумму значений столбца сумма заказа. Обратите внимание на использование двух различных псевдонимов для одной и той же таблицы. При выполнении данного запроса на удаление происходит, как и положено в случае связанных подзапросов, последовательный просмотр записей в таблице продажи. Для каждой записи проверяется условие оператора WHERE, а именно выполняется подзапрос, вычисляющий сумму значений столбца сумма заказа для всех записей, в которых идентификатор клиента равен значению этого идентификатора в текущей записи (текущей называется запись, просматриваемая в данный момент). Если вычисленное значение не превышает 1000, то условие оператора WHERE выполняется и текущая запись удаляется, в противном случае запись не удаляется. Далее происходит переход к следующей записи, рассматриваемой в качестве текущей, и описанные действия повторяются снова. Теперь рассмотрим пример, в котором требуется удалить записи в одной таблице в соответствии с условием, обрабатывающим записи в другой таблице. Допустим, в базе данных имеются две таблицы:
1. Продажи (ID_товара, Сумма_заказа, ID_клиента); 2. Клиенты (ID_клиента, Имя, Адрес).
Требуется удалить из таблицы клиенты те записи о клиентах, которые приобрели товары на сумму, меньшую 1000. Суммы заказов клиентов содержатся в таблице продажи, а записи необходимо удалять из таблицы клиенты, в которой нет данных о приобретенных товарах. Тем не менее, для решения этой задачи можно использовать запрос, аналогичный предыдущему:
DELETE РВОМ Клиенты Tl WHERE 1000 > = (SELECT SUM(T2. Сумма_заказа) FROM Продажи T2 WHERE Т1. ID_клиента= Т2. ID_клиента); Операция удаления записей из таблицы является опасной в том смысле, что связана с риском необратимых потерь данных в случае семантических (но не синтаксических) ошибок при формулировке SQL-выражения. Чтобы избежать неприятностей, перед удалением записей рекомендуется сначала выполнить соответствующий запрос на выборку, чтобы просмотреть, какие записи будут удалены. Так, например, перед выполнением рассмотренного ранее запроса на удаление не помешает выполнить соответствующий запрос на выборку:
SELECT * FROM Клиенты T1 WHERE 1000 > = (SELECT SUM(T2. Сумма_заказа) FROM Продажи Т2 WHERE T1. ID_клиента = T2. ID_клиента);
Для удаления всех записей из таблицы достаточно использовать оператор DELETE без ключевого слова WHERE. При этом сама таблица со всеми определенными в ней столбцами остается и готова для вставки новых записей.
Например: DELETE FROM Клиенты; Таблица может иметь ограничения, которые могут препятствовать удалению некоторых или всех записей.
|
|||
|