失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql 查询重复 Mysql如何去掉数据库中的重复记录 – 数据库 – 前端 mysql 时间比较函数

mysql 查询重复 Mysql如何去掉数据库中的重复记录 – 数据库 – 前端 mysql 时间比较函数

时间:2020-01-30 14:11:20

相关推荐

mysql 查询重复 Mysql如何去掉数据库中的重复记录 – 数据库 – 前端 mysql 时间比较函数

这两天做了一个调用第三方接口的小程序,因为是实时更新数据,所以请求接口的频率就很高,这样有时会出现往数据库插入重复的数据,对数据库造成压力也不方便管理,因为要通过原生sql语句,解决数据库的去重问题.在过程中遇到了麻烦,最终解决了分享出来。

要删除重复的记录,就要先查出重复的记录,这个很容易做到

select * from cqssc group by expect having count(expect) > 1

注意:这是查出所有重复记录的第一条记录,需要保留,因此需要添加查询条件,查出这三条的重复记录

select id,expect from cqssc where expect in (select expect from cqssc group by expect having count(expect)>1)

and id not in(select min(id) from cqssc group by expect having count(expect)>1)

以上得到的结果就是大家需要删除的记录!

下面是偶最初做错的地方,既然要删除,可能都会想到这样很简单了

报错了!!!在Mysql中是不能删除查询出来的记录的,这里很容易错,当时在这里纠结了很久,而是要通过一张临时表来解决。

delete from cqssc where id in (select id from (select id from cqssc where expect in

(select expect from cqssc group by expect having count(expect)>1) and id not in

(select min(id) from cqssc group by expect having count(expect)>1)) as tmpresult)

再运行试试

删除成功,最后再查询一下看是否还有重复记录

可以戳原文看看:/jdbeyond/p/8157224.html

如果觉得《mysql 查询重复 Mysql如何去掉数据库中的重复记录 – 数据库 – 前端 mysql 时间比较函数》对你有帮助,请点赞、收藏,并留下你的观点哦!

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