在關係資料庫管理系統中,表建立時各數據之間的關係不必確定,常把一個實體的所有資訊存放在一個表中。當檢索數據時,通過連接操作查詢出存放在多個表中的不同實體的資訊。連接操作給用戶帶來很大的靈活性,它們可以在任何時候增加新的數據類型。為不同實體創建新的表,之後通過連接進行查詢。
連接可以在SELECT
語句的FROM
子句或WHERE
子句中建立,似是而非在FROM子句中指出連接時有助於將連接操作與WHERE子句中的搜索條件區分開來。所以,在Transact-SQL中推薦使用這種方法。
SQL-92標準所定義的FROM子句的連接語法格式為:
FROM join_table join_type join_table
[ON (join_condition)]
其中join_table
指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一個表操作的連接又稱做自連接。join_type
指出連接類型,可分為三種:內連接、外連接和交叉連接。
內連接(
INNER JOIN
)使用比較運算符進行表間某(些)列數據的比較操作,並列出這些表中與連接條件相匹配的數據行。根據所使用的比較方式不同,內連接又分為等值連 接、自然連接和不等連接三種。外連接分為左外連接(
LEFT OUTER JOIN
或LEFT JOIN
)、右外連接(RIGHT OUTER JOIN
或RIGHT JOIN
)和全外連接(FULL OUTER JOIN
或FULL JOIN
)三種。與內連接不同的是,外連接不只列出與連接條件相匹配的行,而是列出左表(左外連接時)、右表(右外連接時)或兩個表(全外連接時)中所有 符合搜索條件的數據行。交叉連接(
CROSS JOIN
)沒有WHERE
子句,它返回連接表中所有數據行的笛卡爾積,其結果集合中的數據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
連接操作中的ON (join_condition)
子句指出連接條件,它由被連接表中的列和比較運算符、邏輯運算符等構成。
- 連接表 - 簡要概述SQL Server中的連接類型,包括內連接,左連接,右連接和完全外連接。
- INNER JOIN - 從表中選擇在另一個表中具有匹配行的行。
- LEFT JOIN - 返回左表中的所有行以及右表中的匹配行。 如果右表沒有匹配的行,請對右表中的列值使用
NULL
值。 - RIGHT JOIN - 學習左連接的反轉版本 - 右連接。
- FULL OUTER JOIN - 如果不存在匹配的行,則返回左右表中的匹配行以及每側的行。
- CROSS JOIN - 連接多個不相關的表,並在連接表中創建行的笛卡爾積。
- 自聯接 - 顯示如何使用自聯接查詢分層數據並比較同一表中的行。