SQL 多表連接查詢實(shí)現(xiàn)語句
只要兩個(gè)表的公共字段有匹配值,就將這兩個(gè)表中的記錄組合起來。
個(gè)人理解:以一個(gè)共同的字段求兩個(gè)表中符合要求的交集,并將每個(gè)表符合要求的記錄以共同的字段為牽引合并起來。
語法
select * FROM table1 INNER JOIN table2 ON table1 . field1 compopr table2 . field2
INNER JOIN 操作包含以下部分:
部分 | 說明 |
table1, table2 | 要組合其中的記錄的表的名稱。 |
field1,field2 | 要聯(lián)接的字段的名稱。如果它們不是數(shù)字,則這些字段的數(shù)據(jù)類型必須相同,并且包含同類數(shù)據(jù),但是,它們不必具有相同的名稱。 |
compopr |
任何關(guān)系比較運(yùn)算符:“=”、“<”、“>”、“<=”、“>=”或者“<>”。 |
說明
可以在任何 FROM 子句中使用 INNER JOIN 操作。這是最常用的聯(lián)接類型。只要兩個(gè)表的公共字段上存在相匹配的值,Inner 聯(lián)接就會(huì)組合這些表中的記錄。
可以將 INNER JOIN 用于 Departments 及 Employees 表,以選擇出每個(gè)部門的所有雇員。而要選擇所有部分(即使某些部門中并沒有被分配雇員)或者所有雇員(即使某些雇員沒有分配到任何部門),則可以通過 LEFT JOIN 或者 RIGHT JOIN 操作來創(chuàng)建外部聯(lián)接。
如果試圖聯(lián)接包含備注或 OLE 對(duì)象數(shù)據(jù)的字段,將發(fā)生錯(cuò)誤。
可以聯(lián)接任何兩個(gè)相似類型的數(shù)字字段。例如,可以聯(lián)接自動(dòng)編號(hào)和長(zhǎng)整型字段,因?yàn)樗鼈兙窍嗨祁愋?。然而,不能?lián)接單精度型和雙精度型類型字段。
下例展示了如何通過 CategoryID 字段聯(lián)接 Categories 和 Products 表:
SELECT CategoryName, ProductName
FROM Categories INNER JOIN Products
ON Categories.CategoryID = Products.CategoryID;
在前面的示例中,CategoryID 是被聯(lián)接字段,但是它不包含在查詢輸出中,因?yàn)樗话?SELECT 語句中。若要包含被聯(lián)接字段,請(qǐng)?jiān)?SELECT 語句中包含該字段名,在本例中是指 Categories.CategoryID。
也可以在 JOIN 語句中鏈接多個(gè) ON 子句,請(qǐng)使用如下語法:
SELECT fields
FROM table1 INNER JOIN table2
ON table1.field1 compopr table2.field1 AND
ON table1.field2 compopr table2.field2 OR
ON table1.field3 compopr table2.field3;
也可以通過如下語法嵌套 JOIN 語句:
SELECT fields
FROM table1 INNER JOIN
(table2 INNER JOIN [( ]table3
[INNER JOIN [( ]tablex [INNER JOIN ...)]
ON table3.field3 compopr tablex.fieldx)]
ON table2.field2 compopr table3.field3)
ON table1.field1 compopr table2.field2;
LEFT JOIN 或 RIGHT JOIN 可以嵌套在 INNER JOIN 之中,但是 INNER JOIN 不能嵌套于 LEFT JOIN 或 RIGHT JOIN 之中。
2.操作實(shí)例
表A記錄如下:
aID aNum
1 a20050111
2 a20050112
3 a20050113
4 a20050114
5 a20050115
表B記錄如下:
bID bName
1 2006032401
2 2006032402
3 2006032403
4 2006032404
8 2006032408
實(shí)驗(yàn)如下:
1.left join
sql語句如下:
select * from A
left join B
on A.aID = B.bID
結(jié)果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
5 a20050115 NULL NULL
(所影響的行數(shù)為 5 行)
結(jié)果說明:
left join是以A表的記錄為基礎(chǔ)的,A可以看成左表,B可以看成右表,left join是以左表為準(zhǔn)的.
換句話說,左表(A)的記錄將會(huì)全部表示出來,而右表(B)只會(huì)顯示符合搜索條件的記錄(例子中為: A.aID = B.bID).
B表記錄不足的地方均為NULL.
2.right join
sql語句如下:
select * from A
right join B
on A.aID = B.bID
結(jié)果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
NULL NULL 8 2006032408
(所影響的行數(shù)為 5 行)
結(jié)果說明:
仔細(xì)觀察一下,就會(huì)發(fā)現(xiàn),和left join的結(jié)果剛好相反,這次是以右表(B)為基礎(chǔ)的,A表不足的地方用NULL填充.
3.inner join
sql語句如下:
select * from A
innerjoin B
on A.aID = B.bID
結(jié)果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
結(jié)果說明:
很明顯,這里只顯示出了 A.aID = B.bID的記錄.這說明inner join并不以誰為基礎(chǔ),它只顯示符合條件的記錄. 還有就是inner join 可以結(jié)合where語句來使用 如: select * from A innerjoin B on A.aID = B.bID where b.bname='2006032401' 這樣的話 就只會(huì)放回一條數(shù)據(jù)了
個(gè)人總結(jié):將多張表安裝以上三種規(guī)則連接成一張表
相關(guān)文章
SQL Server 使用join all優(yōu)化 or 查詢速度
一個(gè)老項(xiàng)目,加載列表奇慢,超過10秒鐘, 主要涉及兩個(gè)表, user表,procuts表。因?yàn)樯婕岸鄬哟?,使用site字段保存目錄2020-09-09關(guān)于SQL 存儲(chǔ)過程入門基礎(chǔ)(基礎(chǔ)知識(shí))
本篇文章,小編將為大家介紹關(guān)于SQL 存儲(chǔ)過程入門基礎(chǔ)(基礎(chǔ)知識(shí)),有需要的朋友可以參考一下2013-04-04解析Mybatis對(duì)sql表的一對(duì)多查詢問題
這篇文章主要介紹了解析Mybatis對(duì)sql表的一對(duì)多查詢,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06mssql中得到當(dāng)天數(shù)據(jù)的語句
mssql中得到當(dāng)天數(shù)據(jù)的語句...2007-08-08SQL建立數(shù)據(jù)庫及刪除數(shù)據(jù)庫命令
SQL建立數(shù)據(jù)庫及刪除數(shù)據(jù)庫命令,需要使用sqlserver的朋友可以參考下。2011-11-11SQL 統(tǒng)計(jì)一個(gè)數(shù)據(jù)庫中所有表記錄的數(shù)量
最近公司的數(shù)據(jù)庫發(fā)現(xiàn)有表的數(shù)據(jù)被弄掉了,有些數(shù)據(jù)表記錄為0,于是想找出此數(shù)據(jù)庫中到底有哪些數(shù)據(jù)表的記錄都為0以縮小分析范圍,可使用如下的SQL Statement2012-01-01SQLSERVER調(diào)用C#的代碼實(shí)現(xiàn)
本文主要介紹了SQLSERVER調(diào)用C#的代碼實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01