gpt4 book ai didi

mysql - 如何删除用户的所有数据但排除某些数据

转载 作者:行者123 更新时间:2023-11-29 16:36:20 24 4
gpt4 key购买 nike

我有两种不同类型的用户,他们可以具有相同的用户 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com