作者:D大龙 | 来源:互联网 | 2023-05-17 12:21
题意:查找表中重复的.此题是很典型的对分组结果进行统计筛选例题,因此可以利用进行分组,然后使用统计.此处,对与`groupby`进行比较(引用自:):后不能跟聚合函数,因为执行顺序
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
进行比较(引用自:):
需要了解更多数据库技术:LeetCode——Duplicate Emails(使用group by以及having解决分组统计结果),都可以关注数据库技术分享栏目—编程笔记
where
后不能跟聚合函数,因为where
执行顺序大于聚合函数。
where
子句的作用是在对查询结果进行分组前,将不符合where
条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where
条件显示特定的行。
having
子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having
条件显示特定的组,也可以使用多个分组标准进行分组。