MySQL удаление "дочерних" данных

программирование MySQL базы данных

При удалении клиента необходимо удалить все его заявки, а также связанные данные о продажах по этим заявкам. Как реализовать удаление клиента и всех "дочерних" данных через один запрос delete?

Пример моей попытки:
"delete clients.* from clients left join requests on cl_login=rq_cl_login
left join sales on rq_id=sl_rq_id left join sold_goods on sl_rq_id=sgd_rq_id where cl_login='Fox';"

Ошибка 1451

Примечание:
Пожалуй, это действительно лучший вариант, так как другого просто не нашел. Решил проблему отправкой запроса select на все дочерние id, связанные с удаляемым, после чего, все в цикле удаляются по очереди с конца, благо не сложно это на клиентской части в C# реализовать.
Ответы:
Во-первых, у Вас синтаксис запроса неправильный, между delete и from явно лишние слова.
Во-вторых, некоторые СУБД поддерживает такую штуку - cascade on delete. Это констрейнт в схеме базы, можете погуглить, поддерживается ли он в MySQL.
Ну и в-третьих, для подобных задач обычно пишутся хранимые процедуры, даже если cascade on delete поддерживается на уровне СУБД. Вот этой дорогой и советую двигаться


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.