mysql 从多个表中删除行,MySQL从多个表中删除行

Is this the correct way to do it?

DELETE t1, t2, t3, t4 FROM

table1 as t1

INNER JOIN table2 as t2 on t1.id = t2.id

INNER JOIN table3 as t3 on t1.id=t3.id

INNER JOIN table4 as t4 on t1.id=t4.id

WHERE t1.username='%s' AND t1.id='%s'

解决方案

Yes, that is correct. It works fine here:

CREATE TABLE table1 (id int, username nvarchar(30));

CREATE TABLE table2 (id int);

CREATE TABLE table3 (id int);

CREATE TABLE table4 (id int);

INSERT INTO table1 VALUES (1, 'Foo'),(2, 'Bar');

INSERT INTO table2 VALUES (1),(2);

INSERT INTO table3 VALUES (1),(2);

INSERT INTO table4 VALUES (1),(2);

SELECT COUNT(*) FROM table1;

2

SELECT COUNT(*) FROM table2;

2

SELECT COUNT(*) FROM table3;

2

SELECT COUNT(*) FROM table4;

2

DELETE t1, t2, t3, t4 FROM

table1 as t1

INNER JOIN table2 as t2 on t1.id = t2.id

INNER JOIN table3 as t3 on t1.id=t3.id

INNER JOIN table4 as t4 on t1.id=t4.id

WHERE t1.username='Foo' AND t1.id='1';

SELECT COUNT(*) FROM table1;

1

SELECT COUNT(*) FROM table2;

1

SELECT COUNT(*) FROM table3;

1

SELECT COUNT(*) FROM table4;

1

If it's not working for you, perhaps you can modify this example to show what problem you are having.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值