我有两种不同类型的用户,他们可以具有相同的用户 ID。我只想删除表“媒体”和“通知”中用户类型 A 的数据。因此我使用 WHERE 函数。这很有效,因为我只删除 A 类用户。但是,当“媒体”和/或“通知”表中不存在这些用户时,其他表中的所有数据都不会删除,因为它们不符合 WHERE 要求。
所以我的问题是:如何删除符合 WHERE 要求的用户的所有数据,并且如果“媒体”和“通知”表中不存在这些数据,仍然删除其他表中的所有数据。
这是我现在使用的查询:
DELETE `cards`, `users`,`media`,`notifications`
FROM `users`
LEFT JOIN `cards` ON `cards`.`user_id` = `users`.`id`
LEFT JOIN `media` ON `media`.`model_id` = `users`.`id`
LEFT JOIN `notifications` ON `notifications`.`notifiable_id` = `users`.`id`
WHERE `users`.`id` = 88 AND `media`.`model_type` LIKE '%User%' AND `notifications`.`type` LIKE '%Workseeker%'
欢迎所有帮助! :)
最佳答案
我想这就是你想要的:
DELETE `cards`, `users`,`media`,`notifications`
FROM `users`
LEFT JOIN `cards` ON `cards`.`user_id` = `users`.`id`
LEFT JOIN `media` ON `media`.`model_id` = `users`.`id`
LEFT JOIN `notifications` ON `notifications`.`notifiable_id` = `users`.`id`
WHERE `users`.`id` = 88 AND (`media`.`model_type` LIKE '%User%' OR `media`.`model_type` IS NULL) AND (`notifications`.`type` LIKE '%Workseeker%' OR `notifications`.`type` IS NULL)
关于mysql - 如何删除用户的所有数据但排除某些数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53582316/