sql如何删除重复的数据(用SQL语句删除数据库重复数据)

 2024-08-03  阅读 703  评论 0

摘要:原文链接 http://t.zoukankan.com/c-Ajing-p-13448349.html在实际开发中,可能会遇到数据库多条数据重复了,此时我们需要删除重复数据,只保留一条有效数据,用SQL语句怎么实现呢,下面我们模拟一下:1.准备重复数据:2.过滤出存在重复数据的信息:SQL语句:SE
原文链接 http://t.zoukankan.com/c-Ajing-p-13448349.html

在实际开发中,可能会遇到数据库多条数据重复了,此时我们需要删除重复数据,只保留一条有效数据,用SQL语句怎么实现呢,下面我们模拟一下:

1.准备重复数据:

sql如何删除重复的数据(用SQL语句删除数据库重复数据)(1)

2.过滤出存在重复数据的信息:

SQL语句:

SELECT dname FROM dept GROUP BY dname HAVING count( dname ) >1

数据库筛选结果:

sql如何删除重复的数据(用SQL语句删除数据库重复数据)(2)

3.从重复数据中筛选出一条需要保存的数据:

SQL语句:

SELECT min( deptno ) -- max( deptno ) FROM dept GROUP BY dname HAVING count( dname ) >1

这里使用数据库的MIN或者MAX函数筛选出一条需要保存数据即可。

数据库筛选结果:

sql如何删除重复的数据(用SQL语句删除数据库重复数据)(3)

4.删除重复数据,即从重复的数据中,删除掉需要保留数据之外的所有信息:

SQL:

DELETE FROM dept WHERE dname IN ( SELECT dname FROM dept GROUP BY dname HAVING count( dname ) > 1 ) -- 过滤出重复的dname AND deptno NOT IN ( SELECT min( deptno ) AS deptno FROM dept GROUP BY dname HAVING count( dname ) > 1 ) -- 过滤出不在需要保留的id之外的所有id

如果是oracle数据库,上面的SQL语句可以正常执行,可是换成mysql数据库,SQL语句执行会报错:

1093 - You can't specify target table 'dept' for update in FROM clause

含义:不能在同一表中查询的数据作为同一表的更新数据。

适用于mysql数据库的SQL:

DELETE FROM dept WHERE dname IN ( SELECT * FROM ( SELECT dname FROM dept GROUP BY dname HAVING count( dname ) > 1 ) a ) AND deptno NOT IN ( SELECT * FROM ( SELECT min( deptno ) AS deptno FROM dept GROUP BY dname HAVING count( dname ) > 1 ) b )

数据库最后数据:

sql如何删除重复的数据(用SQL语句删除数据库重复数据)(4)

到这里,删除重复数据成功!

一颗安安静静的小韭菜。文中如果有什么错误,欢迎指出。

,

版权声明:xxxxxxxxx;

原文链接:http://cn.tdroid.net/cefd0Cz0EAQ0FUVI.html

发表评论:

管理员

  • 内容265804
  • 积分0
  • 金币0
关于我们
lecms主程序为免费提供使用,使用者不得将本系统应用于任何形式的非法用途,由此产生的一切法律风险,需由使用者自行承担,与本站和开发者无关。一旦使用lecms,表示您即承认您已阅读、理解并同意受此条款的约束,并遵守所有相应法律和法规。
联系方式
电话:
地址:广东省中山市
Email:
注册登录
注册帐号
登录帐号

Copyright © 2022 太卓开发网 Inc. 保留所有权利。 泰达科技网易库网

页面耗时0.1050秒, 内存占用1.33 MB, 访问数据库18次