这篇文章主要介绍了mysql查找删除重复数据并只保留一条实例详解的相关资料,需要的朋友可以参考下

有这样一张表,表数据及结果如下:

school_idschool_nametotal_studenttest_takers1239Abraham Lincoln High School55501240Abraham Lincoln High School70351241Acalanes High School120891242Academy Of The Canyons30301243Agoura High School89401244Agoura High School10050

我们可以看出,school_name的字段值有重复数据(Abraham Lincoln High School 和Agoura High School分别出现两次),那么如何删除这两条数据,从而只让这两个数值出现一次呢? 具体实现方法如下:

1、删除重复记录,保存Id最小的一条

delete FROM `test` WHERE `school_name` in (SELECT `school_name`
FROM `test` 
GROUP BY `school_name` 
HAVING COUNT( * ) >1) and school_id not in (select min(school_id) from test group by school_id having count(* )>1)

先使用GROUP BY having语法查询出重复的数据,然后删除重复数据并保留school_id最小的一条.

2、删除重复记录,保存Id最大的一条

delete FROM `test` WHERE `school_name` in (SELECT `school_name`
FROM `test` 
GROUP BY `school_name` 
HAVING COUNT( * ) >1) and school_id not in (select max(school_id) from test group by school_id having count(* )>1)

原理和上面一样。

以上就是mysql查找删除重复数据并只保留一条实例详解,希望能帮助到大家,谢谢大家对本站的支持!

    无相关信息
最新资讯
腾讯高管解读财报:部分网剧延迟上线冲击广告营收

腾讯高管解读财报:部分

首席战略官米歇尔:“某些视频内容的发布是有所延迟,比如
直击|中联航前高管加盟瑞幸任副总裁 负责战略合作

直击|中联航前高管加

3月21日晚间消息,瑞幸咖啡今日宣布,中国联合航空有限公
Windows 7获KB4493132更新:显示即将停止支持通知

Windows 7获KB4493132

微软近期确认将会向Windows 7设备发送停止支持通知,以
直击|中移动杨杰:将实施5G+计划 改变4G单一计费模式

直击|中移动杨杰:将实

杨杰称,5G和4G将长期并存,中国移动将推动5G和4G协同,满足
宜信正考虑将宜信普惠与宜人贷合二为一

宜信正考虑将宜信普惠

宜信公司正考虑合并旗下美股上市的子公司宜人贷和线下
华为电视机下月出?华星光电称正洽谈合作

华为电视机下月出?华星

原标题:华为电视机下月出?华为称不知悉情况,华星光电称正
最新文章
php基于Redis消息队列实现的消息推送的方法

php基于Redis消息队列

这篇文章主要介绍了php基于Redis消息队列实现的消息推
php使用curl模拟浏览器表单上传文件或者图片的方法

php使用curl模拟浏览

这篇文章主要介绍了php使用curl模拟浏览器表单上传文
safari下载文件自动加了html后缀问题

safari下载文件自动加

这篇文章主要介绍了safari下载文件自动加了html后缀问
ThinkPHP 3.2.3实现加减乘除图片验证码

ThinkPHP 3.2.3实现加

这篇文章主要为大家详细介绍了ThinkPHP 3.2.3实现加减
关于php unset对json_encode的影响详解

关于php unset对json_

这篇文章主要给大家介绍了关于php unset对json_encode
关于PHP虚拟主机概念及如何选择稳定的PHP虚拟主机

关于PHP虚拟主机概念

PHP是一种HTML内嵌式的语言,是一种在端执行的嵌入HTML