今天在项目中需要清理某个表的垃圾数据,通过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 )
1.定长和变长的分离 如int,char,time所占字节是固定的字段放在一张表 如varchar,text所占字节不确定的字段放在一张表中2.常用字段和不常用字段进行分离,根据查询频率来设计3.一对多的关联表可以添加冗余字段,如商品分类表 和商品表 ,在首页中需要显示每个分类商...
需求查询出存在商品的商品分类. 先看看分类表:id(分类的id) catename(分类名) 1 手机 2 &n...
1.floor(x)返回小于x的整数,向下取整,用法,商品的价格是浮点型的,需要向下取整 eg:select id,title,floor(price) from shopgoods2.rand()返回0-1之间的随机数 select rand() select rand()...
触发器是一种特殊的事务,可以监听到Mysql的(insert/update/delete)的操作并触发相应的(insert/update/delete)操作. 触发器的创建主要有4个要素:(1).监听地点(...
(1).首先我们需要了解limit分页的工作流程demo: SELECT * FROM table LIMIT 10000,5 通常我们会认为以上SQL会从10000条后面取5条,正确的是取出10005条,然后再抛弃前...
概述: 目前我们的表设计,最高级别的范式是6NF,对于PHP程序员而言,我们的表满足3NF即可(范式即规范)【一】1NF (1).所谓1NF,就是指标的属性具有原子性,即表的列不能再分割,不能分割意思是字段本身的含义(例如address字段不能再分割)...