当前位置:首页 > SQL > 正文内容

mysql delete where in,mysql delete where not in,You can't specify target table 'member_extend' for u

高老师5年前 (2020-03-19)SQL1629

今天在项目中需要清理某个表的垃圾数据,通过delete from table  where field in(子查询)失败,特来研究下删除下in和not in的问题

(1).普通in/not in正确

DELETE FROM member_extend WHERE uid IN ( 4, 5 ) 
DELETE FROM member_extend WHERE uid NOT IN ( 4, 5 )

(2).子查询in/not中没有包含where所属的表名,正确

DELETE  FROM  member_extend  WHERE  uid  IN(
    SELECT id  FROM member
)
DELETE  FROM  member_extend  WHERE  uid NOT IN(
    SELECT id  FROM member
)

(3).子查询in中包含where所属的表名,错误:You can't specify target table 'member_extend' for update in FROM clause

DELETE  FROM  member_extend  WHERE   uid  IN(
  SELECT uid FROM member_extend
)
DELETE  FROM  member_extend  WHERE   uid  NOT IN(
  SELECT uid FROM member_extend
)
DELETE  FROM  member_extend  WHERE   uid  NOT IN(
  SELECT b.uid  FROM member  a LEFT JOIN member_extend b on a.id=b.uid
)

通过上面的(3)实例我们可以看出来,在delete where 子查询中不能直接包含where所属的表名,例如我们要删除的是member_extend表的数据,子查询中也直接出现member_extend表的数据,我们只需要再包装一层,并加上别名即可。

上面(3)实例中的正确代码修正后的方式:

DELETE  FROM  member_extend  WHERE   uid  IN(
     SELECT uid FROM (SELECT uid FROM member_extend) a
)
DELETE  FROM  member_extend  WHERE   uid  NOT IN(
     SELECT uid FROM (SELECT uid FROM member_extend) a
)
DELETE  FROM  member_extend  WHERE   uid  NOT IN(
    SELECT uid FROM (SELECT b.uid  FROM member  a LEFT JOIN member_extend b on a.id=b.uid) AS b
)

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.5b1.cn/post/340.html

分享给朋友:

“mysql delete where in,mysql delete where not in,You can't specify target table 'member_extend' for u” 的相关文章

mysql group分组排序

mysql group分组排序

下面的是商品数据表,id是主键,catename是分类,titile是标题,price是价格,现在要求计算每种分类下的商品平均价格.id     catename       &n...

主键primary key是否必须和auto_increment 一起出现

主键primary key是否必须和auto_increment 一起出现

    一般情况下,绝大部分,我们的主键是数字,1 2 3 4...所以我们才让它递增.这并不意味着,他们两个必须要绑定在一起使用.例如我还想将用户表的email字段设置为主键,但是并没有必要为其设置自增。    因此可...

 mysql视图有什么用, mysql视图的学习

mysql视图有什么用, mysql视图的学习

我们从一个结果集中查询信息一般都是select *  from (select...),每次都要编写from (select...)非常麻烦,于是我们将结果集保存起来,这就是视图的便利。创建视图的命令为:create   view  &nb...

mysql表视图管理语句

mysql表视图管理语句

1.查看所有表,包括视图表,show  tables;2.查看表结果,包括视图表,desc  表名3.查看建表过程,show   create   table  表名;4.查看建视图过程,show   create   view...

mysql触发器,mysql触发器语法,mysql创建触发器

mysql触发器,mysql触发器语法,mysql创建触发器

    触发器是一种特殊的事务,可以监听到Mysql的(insert/update/delete)的操作并触发相应的(insert/update/delete)操作.    触发器的创建主要有4个要素:(1).监听地点(...

mysql恢复数据库,mysql数据库log文件恢复数据库

mysql恢复数据库,mysql数据库log文件恢复数据库

由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修...