SQL刪除重復(fù)的電子郵箱力扣題目解答流程
寫在前面
想要掌握好SQL,那少不了每天的練習(xí)與學(xué)習(xí)。接下來(lái)小夢(mèng)會(huì)帶領(lǐng)小伙伴們一起每天刷一道LeetCode-數(shù)據(jù)庫(kù)(SQL)相關(guān)的題目,然后在文章后例舉相關(guān)知識(shí)點(diǎn)幫助小伙伴們學(xué)習(xí)與鞏固,更好的掌握SQL。
??♂? 小伙伴們?nèi)绻趯W(xué)習(xí)過(guò)程中有不明白的地方,歡迎評(píng)論區(qū)留言提問(wèn),小夢(mèng)定知無(wú)不言,言無(wú)不盡。

SQL題目概述
題目:
編寫一個(gè) SQL 查詢,來(lái)刪除 Person 表中所有重復(fù)的電子郵箱,重復(fù)的郵箱里只保留 Id 最小 的那個(gè)。
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 是這個(gè)表的主鍵。
解題思路
- 通過(guò) 自連接 將此表與它自身連接起來(lái),通過(guò)電子郵箱列。
- 然后我們需要找到其他記錄中具有相同電子郵件地址的更大 ID。所以我們通過(guò)ID作比較找出大的數(shù)據(jù),把這個(gè)作為條件添加到WHERE子句中。
- 因?yàn)槲覀円呀?jīng)得到了要?jiǎng)h除的記錄,然后我們使用DELETE語(yǔ)句實(shí)現(xiàn)。
方法實(shí)現(xiàn)
根據(jù)以上解題思路,我們可以很容易寫出題解。
DELETE
pson1
FROM
Person pson1,Person pson2
WHERE
pson1.Email = pson2.Email AND pson1.Id > pson2.Id
代碼測(cè)試
進(jìn)行代碼測(cè)試

與預(yù)期結(jié)果一致,測(cè)試成功,用時(shí)166ms

知識(shí)點(diǎn)小結(jié)
?內(nèi)連接與外連接?
小夢(mèng)用極簡(jiǎn)單的方式帶小伙伴們過(guò)一遍內(nèi)連接與外連接。
表1 classa

表2 classb

1. 內(nèi)連接 inner join (join 默認(rèn)就是內(nèi)連接)
表1與表2的交集,用上面兩個(gè)表演示一下
select
classa.id as aid,classb.id as bid
from
classa
inner join classb on classa.id = classb.id;查詢的結(jié)果是classa與classb的交集

2. 左外連接 left join
結(jié)果集保留左表的所有行,但右表只包含與左表匹配的行。右表相應(yīng)的空行為NULL值。
select
classa.id as aid,classb.id as bid
from
classa
left join classb on classa.id = classb.id;
3. 右外連接 right join
結(jié)果集保留右表的所有行,但左表只包含與右表匹配的行。左表相應(yīng)的空行為NULL值。
select
classa.id as aid,classb.id as bid
from
classa
right join classb on classa.id = classb.id;
4. 全外連接 full join
會(huì)把兩個(gè)表所有的行都顯示在結(jié)果表中。
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?。?!
重要的事情要說(shuō)三遍?。?!那怎么實(shí)現(xiàn)和full join一樣的效果呢?那就要通過(guò)使用union來(lái)實(shí)現(xiàn),具體實(shí)現(xiàn)SQL語(yǔ)句如下
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;
到此這篇關(guān)于SQL刪除重復(fù)的電子郵箱解答流程的文章就介紹到這了,更多相關(guān)SQL 刪除重復(fù)郵箱內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL處理多級(jí)分類,查詢結(jié)果呈樹(shù)形結(jié)構(gòu)
對(duì)于多級(jí)分類常規(guī)的處理方法,很多程序員可能是用程序先讀取一級(jí)分類記錄,然后通過(guò)一級(jí)分類循環(huán)讀取下面的子分類2012-08-08
SQL Server 海量數(shù)據(jù)導(dǎo)入的最快方法
這篇論壇文章(賽迪網(wǎng)技術(shù)社區(qū))詳細(xì)講解了SQL Server海量數(shù)據(jù)導(dǎo)入的最快方法,更多內(nèi)容請(qǐng)參考下文2008-12-12
SQL Server 2005 數(shù)據(jù)庫(kù)轉(zhuǎn) SQL Server 2000的方法小結(jié)
這篇文章主要介紹了SQL Server 2005 數(shù)據(jù)庫(kù)轉(zhuǎn) SQL Server 2000的方法,需要的朋友可以參考下2014-04-04
SQLServer 2008數(shù)據(jù)庫(kù)降級(jí)到2005低版本
SQLServer 2008R2備份的數(shù)據(jù)庫(kù)還原到2008上面時(shí)報(bào)錯(cuò)引發(fā)的思考,如何把SQLServer數(shù)據(jù)庫(kù)從高版本降級(jí)到低版本?本文為大家解答2016-11-11
SQLServer使用 PIVOT 和 UNPIVOT行列轉(zhuǎn)換
本文主要介紹了SQLServer使用 PIVOT 和 UNPIVOT行列轉(zhuǎn)換,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08

