目錄
#SQL的表連接
首頁 資料庫 SQL 一起聊聊SQL的表連接

一起聊聊SQL的表連接

Jun 15, 2022 am 11:55 AM
sql

這篇文章為大家帶來了關於SQL的相關知識,其中主要介紹了關於表連接的相關內容,SQL Server中支援多種連接,包括內連接、左連接、右連接、交叉連接和全外連接,下面一起來看一下,希望對大家有幫助。

一起聊聊SQL的表連接

推薦學習:《SQL教程

#SQL的表連接

在關係資料庫中,數據分佈在多個邏輯表。想要獲得完整有意義的資料集,則需要使用連接來查詢這些表中的資料。 SQL Server中支援多種連接,包括內連接、左連接、右連接、交叉連接和全外連接。

一、內連接

內部連接子句用於查詢來自兩個或多個相關資料表的資料。 INNER JOIN 子句的語法:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id
登入後複製

注意:要查詢的字段,必須要在字段的前面加上表名或表的別名,如:p.product_name
其中FROM後面的是主表,然後INNER JOIN 後面的表格是要連接的表。主表和連接表進行比較,查 找滿足的條件的所有行。連接謂詞的計算結果為true是,則將主表和連接表合併成新的結果集,如下圖所示:

一起聊聊SQL的表連接

內連接的多個表連接,如下所示:

SELECT p.product_name, p.list_price ,c.category_name, b.brand_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id 
INNER JOIN production.brands b ON b.brand_id = p.brand_id
登入後複製

二、左連接

在左連接中使用L​​EFT JOIN 子句用於查詢來自多個表的數據,它會傳回是左表中的所有行和右表中匹配行。若是右表中找不到匹配行,則使用NULL代替顯示,如圖所示:

一起聊聊SQL的表連接

#使用LEFT JOIN 語句進行連接:如下所示:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
LEFT JOIN production.categories c ON c.category_id = p.category_id
登入後複製

在上面的語法中FROM 後面的表是左表(production.products),而LEFT JOIN 後面緊接的右表(production.categories)。

三、右連結

在右邊連接中使用RIGHT JOIN子句來進行兩個資料表或多個資料表查詢。右查詢剛好與左查詢的是相反的,返回右表的所有行和左表的匹配行,若左表找不到匹配行,則返回NULL代替顯示,如圖所示:

一起聊聊SQL的表連接

#使用RIGHT JOIN 語句進行連接:如下所示:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
RIGHT JOIN production.categories c ON c.category_id = p.category_id
登入後複製

在上面的語法中FROM 後面的表是左表(production.products),而RIGHT JOIN 後面緊跟的右表(production.categories)。

四、交叉連接

CROSS JOIN 連接兩個或多個不相關的表。以下是兩個表的CROSS JOIN 的語法,兩種寫法:

SELECT T1.select_list 
FROM T1 CROSS JOIN T2;
登入後複製

SELECT T1.select_list 
FROM T1, T2;
登入後複製

CROSS JOIN 將第一個表(T1)中的每一行與第二個表( T2)中的每一行連接起來。換句話說,交叉連 接回兩個表中行的笛卡爾積。與INNER JOIN或LEFT JOIN不同,交叉連接不會在連接的表之間 建立關係。
假設 T1 表包含三行: 1 , 2 和 3 , T2 表包含三行: A , B 和 C 。 CROSS JOIN 從第一個 表(T1)取得一行,然後為第二個表(T2)中的每一行建立一個新行。然後它對 第一個 表(T1)中的 下一行執行相同操作,依此類推。在此圖中, CROSS JOIN 總共建立了 9 行。

五、自連接

自聯接用於將表連接到自身(同一個表)。它對於查詢分層資料或比較同一個表中的行很有用。
自聯接使用內連接或左連接子句。由於使用自聯接的查詢來引用同一個表,因此表別名用於為查詢 中的表分配不同的名稱。
注意:如果在不使用表別名的情況下在查詢中多次引用同一個表,則會發生錯誤。
範例:

SELECT t1.select_list 
FROM T1 t1INNER JOIN T1 t2 ON t1.category_id = t2.category_id
登入後複製

在INNER JOIN 這裡可以使用其他的子句,例如:LEFT JOIN ,RIGHT JOIN

六、全外連接

FULL OUTER JOIN當左表或右表中存在符合項目時,該指令將傳回所有行。如圖所示:

一起聊聊SQL的表連接

使用FULL OUTER JOIN 查詢pm.projects 表和pm.member 表中的資料:

SELECT m.name member, p.title project 
FROM pm.members m 
FULL OUTER JOIN pm.projects p ON p.id = m.project_id;
登入後複製

pm.projects 表數據:
一起聊聊SQL的表連接

pm.member 表格資料:

一起聊聊SQL的表連接

查詢結果:
一起聊聊SQL的表連接

推薦學習:《SQL教學

以上是一起聊聊SQL的表連接的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

Oracle SQL中除法運算的用法 Oracle SQL中除法運算的用法 Mar 10, 2024 pm 03:06 PM

《OracleSQL中除法運算的用法》在OracleSQL中,除法運算是常見的數學運算之一。在資料查詢和處理過程中,除法運算可以幫助我們計算欄位之間的比例或得出特定數值的邏輯關係。本文將介紹OracleSQL中除法運算的用法,並提供具體的程式碼範例。一、OracleSQL中除法運算的兩種方式在OracleSQL中,除法運算可以用兩種不同的方式來進行

Oracle與DB2的SQL語法比較與區別 Oracle與DB2的SQL語法比較與區別 Mar 11, 2024 pm 12:09 PM

Oracle和DB2是兩個常用的關聯式資料庫管理系統,它們都有自己獨特的SQL語法和特性。本文將針對Oracle和DB2的SQL語法進行比較與區別,並提供具體的程式碼範例。資料庫連接在Oracle中,使用以下語句連接資料庫:CONNECTusername/password@database而在DB2中,連接資料庫的語句如下:CONNECTTOdataba

詳解MyBatis動態SQL標籤中的Set標籤功能 詳解MyBatis動態SQL標籤中的Set標籤功能 Feb 26, 2024 pm 07:48 PM

MyBatis動態SQL標籤解讀:Set標籤用法詳解MyBatis是一個優秀的持久層框架,它提供了豐富的動態SQL標籤,可以靈活地建構資料庫操作語句。其中,Set標籤是用來產生UPDATE語句中SET子句的標籤,在更新作業中非常常用。本文將詳細解讀MyBatis中Set標籤的用法,以及透過具體的程式碼範例來示範其功能。什麼是Set標籤Set標籤用於MyBati

SQL中的identity屬性是什麼意思? SQL中的identity屬性是什麼意思? Feb 19, 2024 am 11:24 AM

SQL中的Identity是什麼,需要具體程式碼範例在SQL中,Identity是一種用於產生自增數字的特殊資料類型,它常用於唯一識別表中的每一行資料。 Identity欄位通常與主鍵列搭配使用,可確保每筆記錄都有獨一無二的識別碼。本文將詳細介紹Identity的使用方式以及一些實際的程式碼範例。 Identity的基本使用方式在建立表格時,可以使用Identit

Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Springboot+Mybatis-plus不使用SQL語句進行多表新增怎麼實現 Jun 02, 2023 am 11:07 AM

在Springboot+Mybatis-plus不使用SQL語句進行多表添加操作我所遇到的問題準備工作在測試環境下模擬思維分解一下:創建出一個帶有參數的BrandDTO對像模擬對後台傳遞參數我所遇到的問題我們都知道,在我們使用Mybatis-plus中進行多表操作是極其困難的,如果你不使用Mybatis-plus-join這一類的工具,你只能去配置對應的Mapper.xml文件,配置又臭又長的ResultMap,然後再寫對應的sql語句,這種方法雖然看上去很麻煩,但具有很高的靈活性,可以讓我們

SQL出現5120錯誤怎麼解決 SQL出現5120錯誤怎麼解決 Mar 06, 2024 pm 04:33 PM

解決方法:1、檢查登入使用者是否具有足夠的權限來存取或操作該資料庫,確保該使用者俱有正確的權限;2、檢查SQL Server服務的帳戶是否具有存取指定檔案或資料夾的權限,確保該帳戶具有足夠的權限來讀取和寫入該文件或資料夾;3、檢查指定的資料庫文件是否已被其他進程打開或鎖定,嘗試關閉或釋放該文件,並重新運行查詢;4、嘗試以管理員身份運行Management Studio等等。

如何使用SQL語句在MySQL中進行資料聚合和統計? 如何使用SQL語句在MySQL中進行資料聚合和統計? Dec 17, 2023 am 08:41 AM

如何使用SQL語句在MySQL中進行資料聚合和統計?在進行資料分析和統計時,資料聚合和統計是非常重要的步驟。 MySQL作為一個功能強大的關聯式資料庫管理系統,提供了豐富的聚合和統計函數,可以很方便地進行資料聚合和統計操作。本文將介紹使用SQL語句在MySQL中進行資料聚合和統計的方法,並提供具體的程式碼範例。一、使用COUNT函數進行計數COUNT函數是最常用

See all articles