首页 > 数据库 > MySQL > 正文

MYSQL中delete删除多表数据与删除关联数据

2024-07-24 12:37:42
字体:
来源:转载
供稿:网友

在mysql中删除数据方法有很多种,最常用的是使用delete来删除记录,下面我来介绍delete删除单条记录与删除多表关联数据的一些简单实例.

1、delete from t1 where 条件

2、delete t1 from t1 where 条件

3、delete t1 from t1,t2 where 条件

4、delete t1,t2 from t1,t2 where 条件

前3者是可行的,第4者不可行,也就是简单用delete语句无法进行多表删除数据操作,不过可以建立级联删除,在两个表之间建立级联删除关系,则可以实现删除一个表的数据时,同时删除另一个表中相关的数据.

1、从数据表t1中把那些id值在数据表t2里有匹配的记录全删除掉,代码如下:

DELETE t1 FROM t1,t2 WHERE t1.id=t2.id    或DELETE FROM t1 USING t1,t2 WHERE t1.id=t2.id

2、从数据表t1里在数据表t2里没有匹配的记录查找出来并删除掉,代码如下:

DELETE t1 FROM t1 LEFT JOIN T2 ON t1.id=t2.id WHERE t2.id IS NULL 或

DELETE FROM t1,USING t1 LEFT JOIN T2 ON t1.id=t2.id WHERE t2.id IS NULL

3、从两个表中找出相同记录的数据并把两个表中的数据都删除掉,代码如下:

DELETE t1,t2 from t1 LEFT JOIN t2 ON t1.id=t2.id WHERE t1.id=25

注意此处的delete t1,t2 from 中的t1,t2不能是别名,代码如下:

  1. delete t1,t2 from table_name as t1 left join table2_name as t2 on t1.id=t2.id where 
  2. table_name.id=25 

在数据里面执行是错误的,MYSQL 版本不小于5.0在5.0中是可以的,上述语句改写成如下:

  1. delete table_name,table2_name from table_name as t1 left join table2_name as t2 on 
  2. t1.id=t2.id where table_name.id=25 

在数据里面执行是错误的,MYSQL 版本小于5.0在5.0中是可以的,DELETE怎样删除关联数据,实现级联删除代码如下:

  1. create TABLE IF NOT EXISTS `dcsmember`( 
  2. `id` int(3) auto_increment not null primary key
  3. `namevarchar(12) not null
  4. `passwordvarchar(40) not null
  5. `phonenumber` char(20), 
  6. `time` DATETIME NOT NULL,  
  7. `jifen` int(8)  not null DEFAULT '20'
  8. `email` varchar(40) NOT NULL
  9. `power` int(2) NOT NULL DEFAULT '1' 
  10. )CHARACTER SET gb2312"; 
  11. create TABLE  IF NOT EXISTS `sp`( 
  12. `spid` int(5) auto_increment not null primary key
  13. `spuserid` int(3) not null
  14. `spname` varchar(12) not null
  15. `spmoney` float(6) not null
  16. `spopt` char(20) not null
  17. `spsay` varchar(50), 
  18. `sptime` DATE DEFAULT '2008-10-01'
  19. `spendor` TINYINT(1) DEFAULT '1'
  20. INDEX ( `spuserid` )  
  21. )CHARACTER SET gb2312"; 
  22. --Vevb.com 
  23. --代码如下 
  24. $sqldel="DELETE FROM dcsmember WHERE email='$value'"

现在我用从会员表中删除会员的资料,还需要删除另外一个表中会员的资料,dcsmember.ID是外码,对应sp.spuserid,怎样写才可以,代码如下:

delete d,s from dcsmember d inner join sp s on d.id = s.spuserid where d.email="xxxxxx".

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表