mysql 关联删除

参考网址:http://www.111cn.net/database/mysql/51146.htm

原网页广告太多,自己抄了下。

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";

$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"

下面是自己的实践:

删除t1表,按照t2的条件,t2表又被t3表限制。逻辑如下:

DELETE t1
FROM
t_sales_query as t1
JOIN t_sales_payment as t2 ON t1.id = t2.sales_id
join t_sales_activity as t3 on t2.ACTIVITY_CODE=t3.ACTIVITY_CODE
WHERE
t3.STATUS=‘‘ and t3.SALES_TIME_END BETWEEN ‘‘ and ‘‘

时间: 2024-12-12 17:00:13

mysql 关联删除的相关文章

mysql关联删除记录

在项目开发过程中,要删除表中的记录数据,但是给的字段值不是本表中的字段值,试了很多方法都没有成功,最后看到这个方法挺好用的: DELETE g FROM ws_group_users g, yf_user u WHERE g.userid=u.id and u.phone=? mysql关联删除记录,布布扣,bubuko.com

mysql关联删除

<delete id="deleteBatchUserOfSp" parameterType="java.lang.String" > delete from uauth.user join uauth.usersp on uauth.user.id = uauth.usersp.userid where uauth.usersp.SPid = #{spid,jdbcType=VARCHAR}</delete>   在做关联删除时这样的sql

MySQL完全删除教程

1.管理工具---服务里面停止Mysql服务. 2.控制面板---卸载Mysql,删除C:\Program Files\MySQL目录. 3.这是最关键一步,只做前面两步,密码还是修改不了,因为MySQL 还有文件,也就是在C:\Documents and Settings\All Users\Application Data里面的MySQL文件夹,这个文件没有清除是MySQL重装出现旧密码的根源所在.于是删除MySQL文件夹. 4.检查C:\WINDOWS目录下是否有my.ini文件,将其删除

MySQL中删除数据的两种方法

转自:http://blog.csdn.net/apache6/article/details/2778878 在MySQL中有两种方法可以删除数据,一种是DELETE语句,另一种是TRUNCATE TABLE语句. DELETE语句可以通过WHERE对要删除的记录进行选择.而使用TRUNCATE TABLE将删除表中的所有记录.因此,DELETE语句更灵活. 如果要清空表中的所有记录,可以使用下面的两种方法: DELETE FROM table1 TRUNCATE TABLE table1 其

Mysql 如何删除数据表中的重复数据!

1.使用distinct查询所有不重复的记录 2.创建数据表相同结构的临时表,将第一步的数据复制进去 create temporary table if not exists student_temp as (select distinct(name), sex from student); 3.truncate table student; 4.insert into student(id,name,sex) select null,name,sex from student_temp; My

mysql 海量数据删除

百度知道 - mysql删除海量数据 MySQL 数据库删除大批量数据的优化 看到这儿的话,最后看下这篇文章,对于操作海量数据的sql深入分析 cnblogs - 深度分析DROP,TRUNCATE与DELETE的区别[我的数据库之路系列] dzh项目海量数据删除实战,看了上面文章,考虑truncate只能删除数据,表没有删掉,我就用了drop 需求,除了dzh_weibo_cache表其余的都要删除 dzh_weibo_cache --2000w dzh_weibo_cache111 --15

mysql批量删除指定前缀或后缀表

今天突然发现我们数据库中多出很多表,后缀名为"copy",预计是navicat直接拷贝导致的,然后要对这些有同样后缀名的表进行删除,假设一个一个选择会非常麻烦,表计较多,在网上找了找方法,网上主要通过sql语句来删除.自己在他的基础上写了一个php文件实现了批量删除表.事实上原理是一样的. 1.MYSQL批量删除 [1]获得批量删除的命令: Select CONCAT( 'drop table ', table_name, ';' ) FROM information_schema.t

MySQL关联left join 条件on与where不同,很实用,但要慎用

在mysql查询中,有时候业务复杂了,不得不写多表查询:很多程序猿前期都喜欢写子查询,因为子查询简单易懂,不容易出问题,但子查询的效率毕竟不如关联查询:关联查询我觉得是把双刃剑,在不懂它的机制时,还是慎用,我碰到过以前的同事,因为关联查询没写好,把奖品(查询活动中奖信息)发错的,还好大奖不是汽车: 网上摘的例子,比较好理解 MySQL关联left join条件on和where条件的区别表的结构 `products` CREATE TABLE `products` ( `pid` int(3) N

MySQL 定时删除数据

存储过程: 1. MySQL 5.0 以后开始支持存储过程. 2. 我们常用的SQL语句在执行的时候需要先编译,然后执行,而存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中(因而执行速度比较快),用户通过制定存错过程的名字并给定参数来调用执行它. Event事件: 1. MySQL 5.1以后开始引入event概念: 2. event 即"时间触发器",通过在特定时间触发SQL语句或者存储过程执行. MySQL 定时删除数据实现方法:mysql存储过程 + even