SQL_DML_Multiple-table Delete 多表刪除的用法

来源:https://www.cnblogs.com/BodhiLeaf/archive/2022/06/27/16414941.html
-Advertisement-
Play Games

1 學習參考 MySQL官方文檔 https://dev.mysql.com/doc/refman/8.0/en/delete.html 節選自 MySQL 8.0 Reference Manual_SQL Statements_Data Manipulation Statements_DELETE ...


1 學習參考

  • MySQL官方文檔
    https://dev.mysql.com/doc/refman/8.0/en/delete.html
  • 節選自
    MySQL 8.0 Reference Manual_SQL Statements_Data Manipulation Statements_DELETE Statement
  • 原文知識點
    Multiple-Table Syntax(多表語法)、Multi-Table Deletes(多表刪除)
  • 請註意
    詳細的拓展知識點請參考原文

2 LeetCode 題目

題目

Person表
+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| email       | varchar |
+-------------+---------+
id是該表的主鍵列。該表的每一行包含一封電子郵件。電子郵件將不包含大寫字母。

要求
編寫一個 SQL 刪除語句來刪除所有重覆的電子郵件,只保留一個id 最小的唯一電子郵件。以任意順序返回結果表。(註意:僅需要寫刪除語句)

示例

輸入: 
Person 表
+----+------------------+
| id | email            |
+----+------------------+
| 1  | [email protected] |
| 2  | [email protected]  |
| 3  | [email protected] |
+----+------------------+
輸出: 
+----+------------------+
| id | email            |
+----+------------------+
| 1  | [email protected] |
| 2  | [email protected]  |
+----+------------------+
解釋: [email protected]重覆兩次。我們保留最小的Id = 1。

用 Multiple-table Delete 解答

DELETE 
	p1 
FROM 
	Person p1, p2 
WHERE
	p1.Email = p2.Email AND p1.Id > p2.Id

3 多表刪除的用法

3.1 Multiple-Table Syntax(多表語法)

第1種DELETE語句

	DELETE [LOW_PRIORITY] [QUICK] [IGNORE]
		tbl_name[.*] [, tbl_name[.*]] ...
		FROM table_references   
		[WHERE where_condition]

第2種DELETE語句

	DELETE [LOW_PRIORITY] [QUICK] [IGNORE]
		FROM tbl_name[.*] [, tbl_name[.*]] ...
		USING table_references   
		[WHERE where_condition]

3.2 Multi-Table Deletes(多表刪除)

你可以在一個 DELETE 語句中指定多個表,根據 WHERE 子句中的條件,從一個或多個表中刪除記錄。你不能在多表DELETE 語句中使用 ORDER BY 或 LIMIT。table_references子句列出了參與連接的表。

  • 對於第一種多表語法,只有在 FROM 子句前列出的表中的匹配記錄被刪除。

  • 對於第二種多表語法,只有從 FROM 子句中列出的表(在 USING 子句之前)的匹配記錄被刪除。這樣做的效果是,你可以同時從許多表中刪除記錄,並且有額外的表只用於搜索。

      DELETE t1
      FROM t1 INNER JOIN t2
      WHERE t1.id=t2.id;
    

    或者

      DELETE
      FROM t1,
      USING t1 INNER JOIN t2
      WHERE t1.id=t2.id ;
    

這些語句在 t1、t2 兩個表中搜索要刪除的記錄,但是只從表t1中刪除匹配的記錄。

前面的例子使用了INNER JOIN。

請註意 !!!
很多地方會使用省略的寫法:FROM t1, t2 ,這和FROM t1 INNER JOIN t2 是一樣的。

多表 DELETE 語句也可以使用SELECT語句中允許的其他類型的連接,例如 LEFT JOIN。例如,要刪除存在於t1中但在t2中沒有匹配的記錄,可以使用LEFT JOIN:DELETE t1 FROM t1 LEFT JOIN t2 ON t1.id=t2.id WHERE t2.id IS NULL;

註意 !!!
如果你為一個表聲明瞭一個別名,你在引用該表時必須使用該別名。
DELETE t1 FROM test AS t1, test2 WHERE ...
多表 DELETE中 的表別名應該只在語句的table_references部分聲明。在其他地方,允許引用別名,但不允許聲明別名。

正確:

DELETE a1, a2 FROM t1 AS a1 INNER JOIN t2 AS a2
WHERE a1.id=a2.id;

DELETE FROM a1, a2 USING t1 AS a1 INNER JOIN t2 AS a2
WHERE a1.id=a2.id;

錯誤:

DELETE t1 AS a1, t2 AS a2 FROM t1 INNER JOIN t2
WHERE a1.id=a2.id;

DELETE FROM t1 AS a1, t2 AS a2 USING t1 INNER JOIN t2
WHERE a1.id=a2.id;

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 事情的起因是收到了一位網友的請求,他的java課設需要設計實現迷宮相關的程式——如標題概括。 我這邊不方便透露相關信息,就只把任務要求寫出來。 演示視頻指路👉: 基於JavaFX圖形界面的迷宮程式演示_嗶哩嗶哩_bilibili 完整代碼鏈接🔎: 網盤:https://pan.baidu.com ...
  • Redis 的定義? 百度百科: Redis(Remote Dictionary Server ),即遠程字典服務,是一個開源的使用ANSI C語言編寫、支持網路、可基於記憶體亦可持久化的日誌型、Key-Value資料庫,並提供多種語言的API。 中文官網: Redis是一個開源(BSD許可),記憶體存 ...
  • 安裝 Redis # 首先安裝依賴gcc, 後面需要使用make編譯redis yum install gcc -y # 進入 /usr/local/src 目錄, 把源碼下載到這裡 cd /usr/local/src # 下載 redis 7.0.2 的源碼,github被牆,可以使用國內的地址 ...
  • 一、前言 項目中之前涉及到胎兒心率圖曲線的繪製,最近項目中還需要添加心電曲線和血樣曲線的繪製功能。今天就來分享一下心電曲線的繪製方式; 二、正文 1、胎兒心率曲線的繪製是通過DrawingVisual來實現的,這裡的心電曲線我也是採用差不多相同的方式來實現的,只是兩者曲線的數據有所區別。心電圖的數據 ...
  • 效果圖先附上: 首先 這是我是參考 教程:使用 SignalR 2 和 MVC 5 實時聊天 | Microsoft Docs 先附上教程: 在“添加新項 - SignalRChat”中,選擇 InstalledVisual> C#>WebSignalR>,然後選擇 SignalR Hub 類 (v ...
  • 這次iNeuOS升級主要升級圖形渲染引擎和增加豐富的圖元信息,可以很快的方案應用。總共增加41個通用和行業領域的圖元應用,增加2154個圖元信息,現在iNeuOS視圖建模功能模塊總共包括5894個行業圖元信息。現在完全支持製作高保真的工藝流程和大屏展示效果。 ...
  • 什麼是工廠模式 工廠模式是最常用的設計模式之一,屬於創建型模式。 有點: 解耦,可以把對象的創建和過程分開 減少代碼量,易於維護 什麼時候用? 當一個抽象類有多個實現的時候,需要多次實例化的時候,就要考慮使用工廠模式。 比如:登錄的抽象類ILoginBusiness,它有2個實現,一個用用戶名密碼登 ...
  • 遠程連接ubuntu 提前準備: 在Ubuntu中安裝好ssh 安裝步驟:1.安裝openssh-server 😒udo apt-get install openssh-server ​ (過程中會確認是否希望繼續執行,按y就可) ​ 2.查看是否安裝成功:ps -e |grep ssh ​ 3. ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...