А теперь предположим, что для того, чтобы система, о который до этого шла речь, находилась в синхронизированном состоянии, для каждого заказчика должен существовать хотя бы один филиал. Самый быстрый способ проверить это - воспользоваться левым объединением с последующим визуальным поиском значений NULL.
Вполне очевидно, что наша система сейчас отнюдь не находится в целостном состоянии. Есть запись о заказчике "ABC Talent Agency", но нет соответствующей записи о существовании хотя бы одного ее филиала. Для того чтобы восстановить целостное состояние системы, по идентификатору заказчика нужно удалить из таблицы clients запись, нарушающую целостность системы.
Листинг 11.51.
mysql> DELETE FROM clients WHERE cid = 102;
Исходя из сказанного выше, можно сделать вывод, что два предыдущих шага можно объединить в один с помощью такого подзапроса...
Листинг 11.52.
mysql> DELETE FROM clients WHERE cid = (SELECT clients.cid FROM clients LEFT JOIN branches USING (cid) WHERE bid IS NOLL);
ERROR 1093: You can't specify target table 'clients' for update in FROM clause
... но не тут-то было!
MySQL не позволит вам удалить или модифицировать данные, когда одновременно производится операция чтения этих данных с помощью подзапроса, т.к. при таком действии существует вероятность того, что ваш подзапрос будет ссылаться на строки, которые уже удалены или изменены. Поэтому таблица, указанная во внешнем операторе DELETE или UPDATE, не может упоминаться в предложении FROM внутреннего подзапроса (об этом и пытался сообщить MySQL в предыдущем сообщении об ошибке).
Лучше всего выполнить предыдущую задачу с помощью проверки EXISTS с использованием внешней ссылки.
Листинг 11.53.
mysql> DELETE FROM clients WHERE NOT EXISTS (SELECT * FROM branches
WHERE branches.cid = clients.cid);
Query OK, 1 row affected (0.11 sec)
Резюме
Подзапросы - это вложенные запросы SELECT, по результатам которых фильтруются запросы, внутри которых они находятся. Подзапросы могут применяться везде, где могут применяться выражения, включая предложения WHERE и HAVING с операторами сравнения или логическими операторами, с проверкой IN, с оператором EXISTS, с предложением FROM внешнего запроса и в таких командах языка ЯМД, как UPDATE и DELETE.
Однако за это удобство приходится платить. Ошибки при написании запросов приводят к возрастанию нагрузки на сервер вашей реляционной СУБД, зачастую вызывая полную деградацию производительности, перечеркивая тем самым все плюсы от использования этой возможности. По этой причине настоятельно советуем разработчикам пользоваться альтернативными методами получения и обработки нужных вам данных, включая объединения (в т.ч. объединения типа UNION) и другие конструкции SQL. Это нужно, прежде всего, для обеспечения оптимальной работы приложения и минимизации расхода ресурсов реляционной СУБД.
ТОП-10 популярных
Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...
БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Магнито-оптический дисковод DynaMO
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Компьютер для гурманов.«Эксимер ДМ»
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Для длинных строк, т.е. строк длиннее 255 символов, в MySQL предусмотрены типы BLOB (Binary Large Object, большой двоичный объект) и...
В дополнение к календарным типам, предназначенным для хранения даты и времени отдельно, MySQL также поддерживает гибридные типы данных DATETIME и...
Вообще, к изменению настроек сервера прибегают очень редко. В MySQL программа заранее настроена так, чтобы соответствовать самым распространенным и основным...
Все о MySQL. Циклические ссылки в операторах update и delete
28-12-2009
<< Предыдущая статья | Следующая статья >> |
Все о MySQL. Подзапросы и другие операторы ЯМД | Все о MySQL. Транзакции |