ТОП-10 популярных


НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...


Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...

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

БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...

Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...


Какую только информацию мы не помещаем на компакт-диски: резервные копии важных данных, музыку, фильмы... Многие полагают, что главное - «купить...

Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...

Размер объему не помеха.
С тех пор как компания Fujitsu отказалась от производства жестких дисков для настольных компьютеров, многие пользователи начали забывать о том,...

ПОД ЛИТЕРОЙ «N»
Aтаку LCD-мониторов не остановить, а масштабы этого наступления даже немного пугают. Судите сами — многие пользователи только начинают приглядываться к новому для...

Internet2, или cтарые песни о новом
Когда-то на заре Интернета, тогдаеще военно-научной сетиAPRAnet, были заложены основныепринципы функционирования«Сети сетей». В их числе — использованиепротокола, называемого сейчасIPv4. В...

Все о MySQL. Циклические ссылки в операторах update и delete


28-12-2009

А теперь предположим, что для того, чтобы система, о который до этого шла речь, на­ходилась в синхронизированном состоянии, для каждого заказчика должен существовать хотя бы один филиал. Самый быстрый способ проверить это - воспользоваться левым объединением с последующим визуальным поиском значений NULL.
Циклические ссылки в операторах update и delete
Циклические ссылки в операторах update и delete
Вполне очевидно, что наша система сейчас отнюдь не находится в целостном состоя­нии. Есть запись о заказчике "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 cli­ents 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. Это нужно, прежде всего, для обеспечения оптимальной работы приложения и минимизации расхода ресурсов реляционной СУБД.

Понравился материал? Поделитесь с друзьями!



<< Предыдущая статьяСледующая статья >>
Все о MySQL. Подзапросы и другие операторы ЯМД Все о MySQL. Транзакции