LeetCode——Duplicate Emails(使用group by以及having解决分组统计结果)
程序员文章站
2023-08-19 23:56:02
题意:查找表中重复的 . 此题是很典型的对分组结果进行统计筛选例题,因此可以利用 进行分组,然后使用 统计. 此处,对 与`group by`进行比较(引用自:): 后不能跟聚合函数,因为 执行顺序大于聚合函数。 子句的作用是在对查询结果进行分组前,将不符合 条件的行去掉,即在分组之前过滤数据,条件 ......
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;
此处,对where
与group by
进行比较(引用自:):
-
where
后不能跟聚合函数,因为where
执行顺序大于聚合函数。 -
where
子句的作用是在对查询结果进行分组前,将不符合where
条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where
条件显示特定的行。 -
having
子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having
条件显示特定的组,也可以使用多个分组标准进行分组。