SQL删除重复的电子邮箱力扣题目解答流程

 更新时间:2022年03月08日 16:11:51   作者:超梦梦梦梦  
小伙伴们都知道,不管是在学习中还是日常工作中,几乎天天是要跟数据库打交道的,为了更好的操作数据库,我们的SQL知识储备是必不可少的

写在前面

想要掌握好SQL,那少不了每天的练习与学习。接下来小梦会带领小伙伴们一起每天刷一道LeetCode-数据库(SQL)相关的题目,然后在文章后例举相关知识点帮助小伙伴们学习与巩固,更好的掌握SQL。

🙋‍♂️ 小伙伴们如果在学习过程中有不明白的地方,欢迎评论区留言提问,小梦定知无不言,言无不尽。

SQL题目概述

题目:

编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。

LeetCode原题连接

https://leetcode-cn.com/problems/delete-duplicate-emails/

Person 表

+----+------------------+
| Id | Email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
| 3 | john@example.com |
+----+------------------+

Id 是这个表的主键。

解题思路

  • 通过  自连接  将此表与它自身连接起来,通过电子邮箱列。
  • 然后我们需要找到其他记录中具有相同电子邮件地址的更大 ID。所以我们通过ID作比较找出大的数据,把这个作为条件添加到WHERE子句中。
  • 因为我们已经得到了要删除的记录,然后我们使用DELETE语句实现。

方法实现

根据以上解题思路,我们可以很容易写出题解。

DELETE 
    pson1
FROM 
    Person pson1,Person pson2
WHERE 
    pson1.Email = pson2.Email AND pson1.Id > pson2.Id
 

代码测试

进行代码测试

 与预期结果一致,测试成功,用时166ms

知识点小结

 ⭐内连接与外连接⭐

小梦用极简单的方式带小伙伴们过一遍内连接与外连接。

 表1 classa             

表2 classb

1. 内连接 inner join (join 默认就是内连接)

表1与表2的交集,用上面两个表演示一下

select 
    classa.id as aid,classb.id as bid 
from 
    classa 
inner join classb on classa.id = classb.id;

 查询的结果是classa与classb的交集

2. 左外连接 left join

结果集保留左表的所有行,但右表只包含与左表匹配的行。右表相应的空行为NULL值。

select 
    classa.id as aid,classb.id as bid 
from 
    classa 
left join classb on classa.id = classb.id;

3. 右外连接 right join

结果集保留右表的所有行,但左表只包含与右表匹配的行。左表相应的空行为NULL值。

select 
    classa.id as aid,classb.id as bid 
from 
    classa 
right join classb on classa.id = classb.id;

4. 全外连接 full join

会把两个表所有的行都显示在结果表中。

select 
    classa.id as aid,classb.id as bid 
from 
    classa 
full join classb on classa.id = classb.id;

小伙伴们注意啦!!!

MySQL不支持full join!!!MySQL不支持full join!!!MySQL不支持full join!!!

重要的事情要说三遍!!!那怎么实现和full join一样的效果呢?那就要通过使用union来实现,具体实现SQL语句如下

select 
    classa.id as aid,classb.id as bid 
from 
    classa left join classb on classa.id = classb.id
union
select 
    classa.id as aid,classb.id as bid 
from 
   classa right join classb on classa.id = classb.id;

到此这篇关于SQL删除重复的电子邮箱解答流程的文章就介绍到这了,更多相关SQL 删除重复邮箱内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • 在SQL Server中将数据导出为XML和Json的方法

    在SQL Server中将数据导出为XML和Json的方法

    这篇文章主要介绍了在SQL Server中将数据导出为XML和Json的方法,需要的朋友可以参考下
    2015-02-02
  • sql server中判断表或临时表是否存在的方法

    sql server中判断表或临时表是否存在的方法

    这篇文章主要介绍了sql server中判断表或临时表是否存在的方法,需要的朋友可以参考下
    2015-11-11
  • 轻量级数据库SQL Server Express LocalDb介绍

    轻量级数据库SQL Server Express LocalDb介绍

    这篇文章介绍了轻量级数据库SQL Server Express LocalDb,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • MSSQL 检查所使用的语句是否符合标准

    MSSQL 检查所使用的语句是否符合标准

    标准SQL和T-SQL之间有很多区别——太多了,这里就不说了。还有,如果你在SQL Server上工作, 那么使用这些私有的扩展是有好处的。
    2009-11-11
  • 几个扩展存储过程使用方法

    几个扩展存储过程使用方法

    sqlserver里面有一些危险的扩展存储过程,可以操作注册表,所以很多情况下,下面的存储过程为了服务器安全都会将这些存储过程删除。不过防御与安全同等重要。下面是具体的注册的操作方法。
    2010-07-07
  • sqlserver数据库实现定时备份任务及清理

    sqlserver数据库实现定时备份任务及清理

    这篇文章主要介绍了sqlserver数据库实现定时备份任务及清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • SQL Server创建链接服务器的存储过程示例分享

    SQL Server创建链接服务器的存储过程示例分享

    创建链接服务器。链接服务器让用户可以对 OLE DB 数据源进行分布式异类查询。在使用 sp_addlinkedserver 创建链接 服务器后,可对该服务器运行分布式查询。
    2014-07-07
  • 关于Mybatis的sql注释问题

    关于Mybatis的sql注释问题

    这篇文章主要介绍了关于Mybatis的sql注释问题,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • SQLServer 镜像功能完全实现

    SQLServer 镜像功能完全实现

    折腾SQLServer 镜像搞了一天,终于有点成果,现在分享出来,之前按网上做的出了很多问题。现在尽量把所遇到的问题都分享出来。
    2011-09-09
  • SQL SERVER里日志LDF文件过大的解决方法

    SQL SERVER里日志LDF文件过大的解决方法

    LDF 文件是 SQL Server 数据库中的日志数据文件,用于记录数据库的事务操作和变更信息,本文将给大家介绍SQL SERVER里日志LDF文件过大的解决方法,文章通过图文结合的方式讲解的非常详细,需要的朋友可以参考下
    2024-07-07

最新评论