失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql删除重复sql_mysql中删除完全重复数据的准确SQL语句

mysql删除重复sql_mysql中删除完全重复数据的准确SQL语句

时间:2020-08-25 01:52:08

相关推荐

mysql删除重复sql_mysql中删除完全重复数据的准确SQL语句

删除数据库中重复的记录,只保留一条

DELETE FROM tb_gps_records WHERE id NOT IN (SELECT bid FROM (SELECT min(id) as bid FROM tb_gps_records GROUP BY busNo,longitude,latitude)as b);

//cityId=287

DELETE FROM tb_gps_records WHERE cityId=287 and id NOT IN (SELECT bid FROM (SELECT min(id) as bid FROM tb_gps_records GROUP BY busNo,longitude,latitude)as b);

案例:

id 姓名 课程名称 分数

1 张三 数学 69

2 李四

数学 89

3 张三

数学 69

删除除了自动编号不同,其他都相同的学生冗余信息

------------------------------------------------------------------------------------------------------

按常理来说,这个sql语句应该是:

delete tablename where id not in(select min(id) from tablename group by

name,kecheng,fenshu);

这种写法在sqlserver或者oracle中是支持的,但是mysql目前是不支持的,会报类似错:You

can't specify target table 'tablename' for update ,这是因为在mysql中不能同时查询一个表的数据再同时进行删除.

目前网上流行的一种解法是:

1)创建一个临时表,讲要查询的列的存入临时表中

create table temp as select ...

2)在temp表和原始表中进行操作

delete from tablename

3)drop temp...

但是这种做法,不仅浪费空间资源,同时也缺乏友好性。通过观察我们发现这类查询要解决的是如何将子查询中的表与主查询中的表区分开来,因此我们可以考虑用别名的方法,将子查询的结果放到一个别名中。

完整的sql语句如下:

DELETE FROM tablename where id not in (select bid

from (select min(id) as bid from tablename group by name,kecheng,fenshu) as b )

;

解释:

select bid from (select min(id) as bid from tablename group by

name,kecheng,fenshu) as b

这个子查询的目的是从b中列出讲筛选结果,即bid的集合。

(select min(id) as bid from tablename group by name,kecheng,fenshu) as b

将分组结果中的最小的bid当做一个心的集合当做一个心的子表b,

注意mid(id)一定要有一个别名,这里取的是bid,作为b的一个列名,因为在上一级查询中要用到这个列名(红色标注)。

如果觉得《mysql删除重复sql_mysql中删除完全重复数据的准确SQL语句》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。