我有很多不同表结构的mysql表,它们都有以下表名和字段名(左边是表名,右边是字段名)
我希望能够在单个查询中使用单个变量(例如$id=somename)删除行的值
user id,
user_image user
user_interest user
user_lang id
user_login user
user_personal user
user_prefer user
user_reviewuser
user_role user_id
user_translang user
user_translate user
user_web id
此外,一个特定的用户标识可能不存在于所有表中。
我完全不知道如何一次将它们全部删除。任何提示都将不胜感激,我看了几个类似的问题,但找不到合适的答案。
您想要创建一个外键约束,并指定"ON DELETE CASCADE"。对于每个对用户有外键的表,您都需要这个。例如,
ALTER TABLE user_image
ADD CONSTRAINT fk_user_image_user FOREIGN KEY (user)
REFERENCES user(id)
ON DELETE CASCADE;
您可以使用多表DELETE
语法。如果任何相关表都没有对应的行,则需要使用LEFT JOIN
。
DELETE user, user_image, user_interest, ...
FROM user
LEFT JOIN user_image ON user.id = user_image.user
LEFT JOIN user_interest ON user.id = user_interest.user
...
WHERE user.id = $id
演示
但是,如果使用外键约束将表关联起来,那么使用ON DELETE CASCADE
,只需从user
表中删除该行,所有相关的行都将被删除。