SQL刪除重復的電子郵箱力扣題目解答流程
寫在前面
想要掌握好SQL,那少不了每天的練習與學習。接下來小夢會帶領小伙伴們一起每天刷一道LeetCode-數(shù)據(jù)庫(SQL)相關的題目,然后在文章后例舉相關知識點幫助小伙伴們學習與鞏固,更好的掌握SQL。
??♂? 小伙伴們?nèi)绻趯W習過程中有不明白的地方,歡迎評論區(qū)留言提問,小夢定知無不言,言無不盡。
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作比較找出大的數(shù)據(jù),把這個作為條件添加到WHERE子句中。
- 因為我們已經(jīng)得到了要刪除的記錄,然后我們使用DELETE語句實現(xiàn)。
方法實現(xiàn)
根據(jù)以上解題思路,我們可以很容易寫出題解。
DELETE pson1 FROM Person pson1,Person pson2 WHERE pson1.Email = pson2.Email AND pson1.Id > pson2.Id
代碼測試
進行代碼測試
與預期結果一致,測試成功,用時166ms
知識點小結
?內(nèi)連接與外連接?
小夢用極簡單的方式帶小伙伴們過一遍內(nèi)連接與外連接。
表1 classa
表2 classb
1. 內(nèi)連接 inner join (join 默認就是內(nèi)連接)
表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;
小伙伴們注意啦?。。?/p>
MySQL不支持full join?。?!MySQL不支持full join?。?!MySQL不支持full join?。。?/p>
重要的事情要說三遍?。?!那怎么實現(xiàn)和full join一樣的效果呢?那就要通過使用union來實現(xiàn),具體實現(xiàn)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 刪除重復郵箱內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SQLServer 參數(shù)化查詢經(jīng)驗分享
本篇文章將介紹參數(shù)化查詢。我將討論如果一個查詢可以被參數(shù)化,那么SQL Server優(yōu)化器怎樣嘗試將其參數(shù)化,以及你可以怎樣建立你自己的參數(shù)化查詢。2010-05-05SQLSERVER語句的執(zhí)行時間顯示的統(tǒng)計結果是什么意思
在SQL語句調(diào)優(yōu)的時候,大部分都會查看語句執(zhí)行時間,究竟SQLSERVER顯示出來的統(tǒng)計結果是什么意思,接下來為您一一解釋,感興趣的朋友可以了解下2013-01-01SqlServer參數(shù)化查詢之where in和like實現(xiàn)詳解
若有一天你不可避免的需要提高SQL的查詢性能,需要一次性where in 幾百、上千、甚至上萬條數(shù)據(jù)時,參數(shù)化查詢將是必然進行的選擇2012-05-05通過T_sql語句向其中一次填入一條數(shù)據(jù)或一次填入多條數(shù)據(jù)的方式填充數(shù)據(jù)
使用T_sql語句向其中一次填入一條數(shù)據(jù)或一次填入多條數(shù)據(jù)的方式填入數(shù)據(jù),需要的朋友可以參考下2012-10-10