sql如何查找重复数据

55次阅读
没有评论

共计 821 个字符,预计需要花费 3 分钟才能阅读完成。

这篇文章主要讲解了“sql 如何查找重复数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“sql 如何查找重复数据”吧!

编写一个 SQL 查询,查找学生表中所有重复的学生名。

【解题思路】

1. 看到“找重复”的关键字眼,首先要用分组函数 (group by),再用聚合函数中的计数函数 count() 给姓名列计数。

2. 分组汇总后,生成了一个如下的表。从这个表里选出计数大于 1 的姓名,就是重复的姓名。

【解题步骤】

方法一

1)创建一个辅助表,将姓名列进行行分组汇总

select 姓名, count(姓名) as 计数

from 学生表

group by 姓名;

2)选出辅助表中计数大于 1 的姓名

select 姓名 from 辅助表

where 计数

3)结合前两步,将“创建辅助表”的步骤放入子查询

select 姓名 from

(

select 姓名, count(姓名) as 计数

from 学生表

group by 姓名

) as 辅助表

where 计数

方法二

这时候有的同学可能会想,为什么要这么麻烦创建一个子查询,不能用这个语句 (将 count 放到 where 字句中) 直接得出答案吗?

select 姓名

from 学生表

group by 姓名

where count(姓名)

如果我们运行下这个 sql 语句,会报下面的错误,问题出在哪里呢?

前面提到聚合函数(count),where 字句无法与聚合函数一起使用。因为 where 子句的运行顺序排在第二,运行到 where 时,表还没有被分组。

如果要对分组查询的结果进行筛选,可以使用 having 子句。所以,这道题的最优方法如下:

select 姓名

from 学生表

group by 姓名

having count(姓名)

感谢各位的阅读,以上就是“sql 如何查找重复数据”的内容了,经过本文的学习后,相信大家对 sql 如何查找重复数据这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-01发表,共计821字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)