MYSQL中delete删除多表数据与删除关联数据
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-02 21:44:31 浏览: 评论:0
在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不能是别名,代码如下:
- delete t1,t2 from table_name as t1 left join table2_name as t2 on t1.id=t2.id where
- table_name.id=25
在数据里面执行是错误的,MYSQL 版本不小于5.0在5.0中是可以的,上述语句改写成如下:
- delete table_name,table2_name from table_name as t1 left join table2_name as t2 on
- t1.id=t2.id where table_name.id=25
在数据里面执行是错误的,MYSQL 版本小于5.0在5.0中是可以的,DELETE怎样删除关联数据,实现级联删除代码如下:
- create TABLE IF NOT EXISTS `dcsmember`(
- `id` int(3) auto_increment not null primary key,
- `name` varchar(12) not null,
- `password` varchar(40) not null,
- `phonenumber` char(20),
- `time` DATETIME NOT NULL,
- `jifen` int(8) not null DEFAULT '20',
- `email` varchar(40) NOT NULL,
- `power` int(2) NOT NULL DEFAULT '1'
- )CHARACTER SET gb2312";
- create TABLE IF NOT EXISTS `sp`(
- `spid` int(5) auto_increment not null primary key,
- `spuserid` int(3) not null,
- `spname` varchar(12) not null,
- `spmoney` float(6) not null,
- `spopt` char(20) not null,
- `spsay` varchar(50),
- `sptime` DATE DEFAULT '2008-10-01',
- `spendor` TINYINT(1) DEFAULT '1',
- INDEX ( `spuserid` )
- )CHARACTER SET gb2312";
- --phpfensi.com
- --代码如下
- $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".
Tags: delete删除多表 MYSQL关联数据
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)