DELETE [LOW_PRIORITY] [QUICK] FROM table_name
[WHERE where_definition]
[ORDER BY ...]
[LIMIT rows]
или
DELETE [LOW_PRIORITY] [QUICK] table_name[.*] [, table_name[.*] ...]
FROM table-references
[WHERE where_definition]
или
DELETE [LOW_PRIORITY] [QUICK]
FROM table_name[.*] [, table_name[.*] ...]
USING table-references
[WHERE where_definition]
Оператор DELETE удаляет из
таблицы table_name строки,
удовлетворяющие заданным в
where_definition условиям, и
возвращает число удаленных
записей.
Если оператор DELETE
запускается без определения
WHERE, то удаляются все
строки. При работе в режиме
AUTOCOMMIT это будет
аналогично использованию
оператора TRUNCATE. See
Раздел 6.4.7, «Синтаксис оператора TRUNCATE». В MySQL 3.23 оператор
DELETE без определения
WHERE возвратит ноль как
число удаленных записей.
Если действительно необходимо
знать число удаленных записей при
удалении всех строк, и если
допустимы потери в скорости, то
можно использовать команду
DELETE в следующей форме:
mysql> DELETE FROM table_name WHERE 1>0;
Следует учитывать, что эта форма
работает намного медленнее, чем
DELETE FROM table_name без
выражения WHERE, поскольку
строки удаляются поочередно по
одной.
Если указано ключевое слово
LOW_PRIORITY, выполнение
данной команды DELETE будет
задержано до тех пор, пока другие
клиенты не завершат чтение этой
таблицы.
Если задан параметр QUICK,
то обработчик таблицы при
выполнении удаления не будет
объединять индексы - в некоторых
случаях это может ускорить данную
операцию.
В таблицах MyISAM удаленные
записи сохраняются в связанном
списке, а последующие операции
INSERT повторно используют
места, где располагались удаленные
записи. Чтобы возвратить
неиспользуемое пространство и
уменьшить размер файлов, можно
применить команду OPTIMIZE
TABLE или утилиту
myisamchk для реорганизации
таблиц. Команда OPTIMIZE TABLE
проще, но утилита myisamchk
работает быстрее. See
Раздел 4.5.1, «Синтаксис команды OPTIMIZE TABLE ». See
Раздел 4.4.6.10, «Оптимизация таблиц».
Первый из числа приведенных в
начале данного раздела
многотабличный формат команды
DELETE поддерживается,
начиная с MySQL 4.0.0. Второй
многотабличный формат
поддерживается, начиная с MySQL 4.0.2.
Идея заключается в том, что
удаляются только совпадающие
строки из таблиц, перечисленных
перед выражениями FROM или
USING. Это позволяет
удалять единовременно строки из
нескольких таблиц, а также
использовать для поиска
дополнительные таблицы.
Символы .* после имен
таблиц требуются только для
совместимости с Access:
DELETE t1,t2 FROM t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id
или
DELETE FROM t1,t2 USING t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id
В предыдущем случае просто удалены
совпадающие строки из таблиц
t1 и t2.
Если применяется выражение
ORDER BY (доступно с версии
MySQL 4.0), то строки будут удалены в
указанном порядке. В
действительности это выражение
полезно только в сочетании с
LIMIT. Например:
DELETE FROM somelog
WHERE user = 'jcole'
ORDER BY timestamp
LIMIT 1
Данный оператор удалит самую
старую запись (по timestamp),
в которой строка соответствует
указанной в выражении
WHERE.
Специфическая для MySQL опция
LIMIT для команды
DELETE указывает серверу
максимальное количество строк,
которые следует удалить до
возврата управления клиенту. Эта
опция может использоваться для
гарантии того, что данная команда
DELETE не потребует слишком
много времени для выполнения.
Можно просто повторять команду
DELETE до тех пор, пока
количество удаленных строк меньше,
чем величина LIMIT.
С MySQL 4.0 вы можете указать множество
таблиц в DELETE чтобы
удалить записи из одной таблицы,
основываясь на условии по
множеству таблиц. Однако, с такой
формой оператора DELETE
нельзя использовать ORDER
BY или LIMIT.
This is a translation of the MySQL Reference Manual that can be found at dev.mysql.com. The original Reference Manual is in English, and this translation is not necessarily as up to date as the English version.
© 1995-2005 MySQL AB. All rights reserved.
