SQL怎么删除重复数据

    1 SQL去重

    SQL中去除完全相同数据可以用distinct关键字,任意字段去重可以用group by,以下面的数据表为例。

    2 distinct

    存在两条完全相同的纪录,用关键字distinct就可以去掉

    根据单个字段去重,能精确去重;

    作用在多个字段时,只有当这几个字段的完全相同时,才能去重;

    关键字distinct只能放在SQL语句中的第一个,才会起作用

    SQL怎么删除重复数据

    SQL怎么删除重复数据

    SQL怎么删除重复数据

    一般用来返回不重复的记录条数,返回不重复的条数(去掉test重复的,就剩下6条)

    SQL怎么删除重复数据

    3 group by

    1. 查询根据名字去重后数据(名字相同取id值大的)

    SELECT * FROM stu WHERE id IN (SELECT MAX(id) FROM stu GROUP BY `name`)

    SQL怎么删除重复数据

    2. 删除名字相同数据(名字相同保留id值大的)

    group by + count + max去掉重复数据

    1)SELECT * FROM stu

    SQL怎么删除重复数据

    2)加上group by 后,会将重复的数据去掉了

    SQL怎么删除重复数据

    3) 条件(名字)是数量大于1的重复数据

    SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`) > 1#条件是数量大于1的重复数据SELECT * FROM stu WHERE `name` IN(SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`)>1 )

    SQL怎么删除重复数据

    4)查看某字段重复数据的id

    SELECT id, COUNT(*) FROM stu GROUP BY NAME DESC HAVING(COUNT(*) > 0)

    SQL怎么删除重复数据

    5)查询所有重复数据

    SELECT * FROM stu WHERE NAME IN (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`) > 1)

    SQL怎么删除重复数据

    5) 去重

    可以使用distinct去重(返回不重复的用户名)

    删除多余的重复记录(name),只保留id最大的记录。

    DELETE FROM stu WHERE id NOT IN ( SELECT a.id FROM ( SELECT MAX( id ) AS id FROM stu GROUP BY `name` )a )

    或者

     DELETE FROM stu WHERE `name` IN (SELECT `name` FROM (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(`name`)>1) e) AND id NOT IN (SELECT id FROM (SELECT MAX(id) AS id FROM stu GROUP BY `name` HAVING COUNT(`name`)>1) t) #查询显示重复的数据都是显示最前面的几条,因此不需要查询是否最小值

    错误删除

    DELETE FROM stu WHERE name IN (SELECT name FROM stu GROUP BY name HAVING COUNT(name)>1)
    AND id NOT IN (SELECT MAX(id) FROM stu GROUP BY stu HAVING COUNT(name)>1)

    原因是:不能将直接查处来的数据当做删除数据的条件,我们应该先把查出来的数据新建一个临时表,然后再把临时表作为条件进行删除功能

    4 总结

    去重后名字记录

    SELECT `name` FROM stu GROUP BY NAME HAVING(COUNT(*) > 0)

    2)

    所有重复名字的记录

    SELECT `name` FROM stu GROUP BY NAME HAVING COUNT(*) > 1

    3)把所有重复的记录都删了

    DELETE FROM stu WHERE name IN
    (SELECT name FROM stu GROUP BY name HAVING COUNT(*)>1)

    SQL怎么删除重复数据

    无法在删除时同时查询这张表,这个问题只在MySQL中出现,oracle没有。怎么解决?我们只需要在查出结果以后加一张中间表。让执行器认为我们要查的数据不是来自正在删的这张表就可以了。

    DELETE FROM stu WHERE `name` IN     (SELECT a.name FROM         (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(*)>1) a)

    所有重复数据都删除, 就剩王五一条数据了

    SQL怎么删除重复数据

    4) 现在删除所有重复数据数据做完了,考虑怎么保留重复数据中id最小的。只需要在删除时让删除该条的记录id不在重复数据id最小的当中就可以了。

    DELETE FROM stu WHERE `name` IN     (SELECT a.name FROM         (SELECT `name` FROM stu GROUP BY `name` HAVING COUNT(*)>1) a)     AND id NOT IN     (SELECT b.id FROM         (SELECT MIN(id) id FROM stu             GROUP BY `name` HAVING COUNT(*)>1) b);

    SQL怎么删除重复数据

    还有简单办法 算出去重后所有数据(保留最小ID),然后删除id不在该数组里的

     DELETE FROM stu WHERE id NOT IN (SELECT t.id FROM (SELECT MIN(id) AS id FROM stu GROUP BY `name`)t)

    到此,关于“SQL怎么删除重复数据”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

    文章标题:SQL怎么删除重复数据,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/27455

    (0)
    打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
    上一篇 2022年9月20日 上午12:23
    下一篇 2022年9月20日 下午11:53

    相关推荐

    • mysql和myisam有哪些区别

      mysql和myisam的区别是:mysql是一个关系型数据库管理系统,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据,而myisam是mysql的默认数据库引擎(5.5版之前),并且不支持事务处理。 本教程操作环境:windows10系统、mysql8.0.22…

      2022年8月27日
      3900
    • windows kb4522741补丁安装失败如何解决

      根据情况可能不同,小编准备了五种解决方案 第一种方案: 1.查看【windows update】、【app readiness】、【Cryptographic Services】、【Background Intelligent Transfer Service】、【Windows Installer…

      2022年9月1日
      4400
    • ai如何转曲图片

      ai转曲图片的方法: 1、首先进入ai,然后新建画布,可以自己调整大小。 2、然后选择里面的“文字工具”。 3、之后输入文字,并且复制3个左右。 4、选择第一个文字,右击点击“创建轮廓”。 5、然后点击“对象”选择“扩展”。 6、调整好了之后点击“确定”。 7、最后选择最后一组的文字,按下“ctrl…

      2022年9月1日
      10300
    • zabbix代理服务器部署与zabbix-snmp监控问题怎么解决

      一、部署zabbix 代理服务器 分布式监控的作用: 分担 server 的集中式压力 解决多机房之间的网络延时问题 bsystemctl disable –now firewalldsetenforce 0hostnamectl set-hostname zbx-proxy 1.1、设置 zab…

      2022年9月18日
      7600
    • windows 0xc000012f如何解决

      解决方法: 方法一: 1、首先,根据错误描述来看,可能是dll文件错误。 2、我们可以直接使用dll修复助手,来一键修复它们。 3、下载安装完成后,运行软件,根据提示关闭杀毒软件就可以自动修复了。 4、修复完成后重启电脑,看看还有没有错误代码。 方法二: 1、如果修复完文件还有错误,那就可以尝试禁用…

      2022年9月15日
      8100
    • Web.config在渗透中的作用是什么

      前言  下面主要介绍web.config文件在渗透中的作用,即可上传一个web.config时的思路,话不多说,开始正题。首先我们来看一下web.config是什么,援引百度百科的介绍:  Web.config文件是一个XML文本文件,它用来储存ASP.NETWeb 应用程序的配置信息,它可以出现在…

      2022年9月24日
      7500
    • 电脑黑白打印机能不能扫描出彩色

      黑白打印机能扫描出彩色的吗 答:黑白打印机能扫描出彩色的。 1、如果你的黑白打印机带有扫描功能,那就可以扫描彩色。 2、因为扫描和打印是分开的,不能打印彩色与扫描彩色没有关系。 3、如果我们想要扫描彩色内容的话,可以先连接打印机,打开它。 4、打开后,在“打印与扫描”下选择“扫描文档或照片” 5、然…

      2022年9月24日
      15100
    • coreldraw如何填充颜色

      coreldraw填充颜色的方法 1、打开软件选择左侧的矩形工具,在工作区域里画出一个矩形。 2、工具栏里面找到填充工具,选择均匀填充。 3、在均匀填充调色框中选择需要填充的颜色,然后点击“确定”。 4、这样就填充完成了。 关于“coreldraw如何填充颜色”的内容就介绍到这里了,感谢大家的阅读。…

      2022年9月26日
      3000
    • Swift的Mirror反射怎么使用

      元类型与.self AnyObject 在Swift开发中,我们经常会使用AnyObject来代表任意类的实例、类的类型、以及仅类遵守的协议。 代表任意类的实例、类的类型 class LGTeacher { var age = 18}var t = LGTeacher()var t1: AnyObj…

      2022年9月24日
      10600
    • 如何进行APT中的迂回渗透

      引言 随着信息安全行业发展,很多企业,政府以及互联网公司对网络安全越来越重视。习大大指出,没有网络安全就没有国家安全,没有信息化就没有现代化。 众所周知,现在的安全产品和设备以及对网络安全的重视,让我们用常规手段对目标渗透测试的成功率大大降低。当然,对于一些手握0day的团队或者个人来说,成功率还是…

      2022年9月21日
      4300
    联系我们
    关注微信
    关注微信
    分享本页
    返回顶部
    PingCode 比 Jira 更好用的研发管理工具。免费试用