当前位置: 萬仟网 > IT编程>数据库>Mysql > LeetCode——Duplicate Emails(使用group by以及having解决分组统计结果)

LeetCode——Duplicate Emails(使用group by以及having解决分组统计结果)

2019年10月09日 17:51  | 萬仟网IT编程  | 我要评论
write a sql query to find all duplicate emails in a table named person.

+----+---------+
| id | email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+
for example, your query should return the following for the above table:

+---------+
| email   |
+---------+
| a@b.com |
+---------+
note: all emails are in lowercase.

题意:查找表中重复的email.
此题是很典型的对分组结果进行统计筛选例题,因此可以利用group by进行分组,然后使用having统计.

# write your mysql query statement below
select email from person group by email having count(email) > 1;

此处,对wheregroup by进行比较(引用自:):

  • where后不能跟聚合函数,因为where执行顺序大于聚合函数。
  • where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。
  • having子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having条件显示特定的组,也可以使用多个分组标准进行分组。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

◎已有 0 人评论

Copyright © 2019  萬仟网 保留所有权利. 粤ICP备17035492号-1
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com