当前位置:   article > 正文

用SQL语句删除数据库重复数据,只保留一条有效数据_sql删除重复数据只保留一条

sql删除重复数据只保留一条

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

1.准备重复数据:
在这里插入图片描述
2.过滤出存在重复数据的信息:

SQL语句:

SELECT
	dname 
FROM
	dept 
GROUP BY
	dname 
HAVING
	count( dname ) >1
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

数据库筛选结果:
在这里插入图片描述
3.从重复数据中筛选出一条需要保存的数据:

SQL语句:

SELECT
	min( deptno ) -- max( deptno )
	
FROM
	dept 
GROUP BY
	dname 
HAVING
	count( dname ) >1
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

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

数据库筛选结果:
在这里插入图片描述
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
	
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

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

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

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

适用于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 )
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

数据库最后数据:
在这里插入图片描述
到这里,删除重复数据成功!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/942115
推荐阅读
相关标签
  

闽ICP备14008679号