having sql示例_SQL GROUP BY和HAVING示例–编写SQL查询以查找重复的电子邮件– LeetCode解决方案...

having sql示例

编写SQL查询以在名为Person的表中查找所有重复的电子邮件。

+----+---------+
| Id | Email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+

例如,您的查询应为上表返回以下内容:

+---------+
| Email   |
+---------+
| a@b.com |
+---------+

注意:所有电子邮件均为小写。

这是解决SQL查询中此问题的三种方法,一种是通过使用group by子句,第二种是使用自联接,然后第三种是使用带有存在子句的子查询。 尽管我同意可以用不同的方法解决此问题,但这也是如何使用
SQL GROUP BY和HAVING子句

解决此问题的最简单方法是使用GROUP BY和HAVING子句。 使用GROUP BY将电子邮件上的结果集分组,这会将所有重复的电子邮件归为一组,现在,如果特定电子邮件的计数大于1,则表示它是重复的电子邮件。 这是查找重复电子邮件SQL查询:

#在下面写你MySQL查询语句

 SELECT Email FROM Person GROUP BY Email HAVING COUNT(Email) > 1 

这也是我接受的有关LeetCode的答案。

顺便说一句,有两种其他方法可以解决此问题,一种方法是使用“自助联接”。 如果您还记得,在“自我联接”中,我们联接同一表的两个实例以将一个记录与另一个记录进行比较。 现在,如果表第一个实例中一个记录的电子邮件等于第二个表中另一个记录的电子邮件,则意味着该电子邮件是重复的。 这是使用自连接SQL查询

#在下面写你MySQL查询语句

 SELECT DISTINCT a.Email FROM Person a JOIN Person b ON a.Email = b. Email WHERE a.Id != b.Id 

请记住在此处使用关键字distant,因为它将重复打印电子邮件,使其重复出现在表格中的次数。 这也是Leetcode中公认的解决方案。

您甚至可以使用相关子查询来解决此问题。 在相关子查询中,将对外部查询中的每个记录执行内部查询。 因此,使用相关子查询将一封电子邮件与同一表中的其余电子邮件进行比较。 这是解决方案查询:

 SELECT DISTINCT p1.Email  FROM Person p1  WHERE EXISTS( 
     SELECT * 
     FROM Person p2 
     WHERE p2.Email = p1.Email 
     AND p2.Id != p1.Id  ) 

如果您仍然需要更多指导,那么Julia Evans这本zine也是了解如何使用带有HAVING子句的GROUP BY在表中查找重复元素的好方法

这就是如何使用GROUP BY和HAVING子句在SQL中查找重复电子邮件的全部内容。 我还向您展示了如何使用自我连接以及带有EXISTS子句的子查询来解决此问题。 一旦熟悉了模式,就可以解决许多此类问题。 如果您想了解更多信息,请查看以下资源。

感谢您阅读本文,如果您喜欢这篇SQL文章,请与您的朋友和同事分享。 如果您有任何疑问或反馈,请留下笔记。

翻译自: https://www.javacodegeeks.com/2020/04/sql-group-by-and-having-example-write-sql-query-to-find-duplicate-emails-leetcode-solution.html

having sql示例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值