inner,outer,left,right join
FROM (((表1 INNER JOIN 表2 ON 表1.字段號(hào)=表2.字段號(hào)) INNER JOIN 表3 ON 表1.字段號(hào)=表3.字段號(hào)) INNER JOIN 表4 ON Member.字段號(hào)=表4.字段號(hào)) INNER JOIN 表X ON Member.字段號(hào)=表X.字段號(hào)
例子:
SELECT *
FROM (((Member INNER JOIN MemberSort ON Member.MemberSort=MemberSort.MemberSort) INNER JOIN MemberLevel ON Member.MemberLevel=MemberLevel.MemberLevel) INNER JOIN MemberIdentity ON Member.MemberIdentity=MemberIdentity.MemberIdentity) INNER JOIN Wedlock ON Member.Wedlock=Wedlock.Wedlock
ORDER BY MemberDate DESC
內(nèi)連接的功能是,把兩個(gè)表相關(guān)聯(lián)的記錄列出來,必須是相關(guān)聯(lián)的記錄。
2) 左外連接,left outer join ... on
語句格式:
FROM [表名1] LEFT JOIN [表名2]
ON [表名1.字段A] 〈關(guān)系運(yùn)算符〉[表名2.字段B]
其實(shí)LEFT JOIN 的功能就是將LEFT左邊的表名1中的所有記錄全部保留,而將右邊的表名2中的字段B與表名1.字段A相對(duì)應(yīng)的記錄顯示出來(當(dāng)使用SELECT * 時(shí))。而RIGHT JOIN 和LEFT JOIN 相反。
外連接的功能是,把LEFT左邊的表中的所有記錄保留,而右邊表只保留相關(guān)聯(lián)的記錄,也就是先執(zhí)行一次INNER JOIN,然后把LEFT左邊的表中的與右邊表沒有任何關(guān)聯(lián)的記錄也保留,而右邊表的字段為null.
3) 右外連接,right outer join ... on
與 left join左右相反。
4) 全連接,full join ... on(不常使用,只能用于outer)
功能結(jié)合了以上三種聯(lián)軍,先執(zhí)行一次inner join,然后把兩個(gè)表的多余字段都保留,但連接的對(duì)應(yīng)字段為null.
如果想將幾個(gè)表聯(lián)接起來,在JOIN操作中我們可以進(jìn)行嵌套操作,有三個(gè)表:表1、表2、表3,現(xiàn)在將三個(gè)表聯(lián)接起來:
FROM (表1 INNER JOIN 表2 ON 表1.序號(hào)=表2.序號(hào))
INNER JOIN 表3 ON 表1.序號(hào)=表3.序號(hào)
=====================
在一個(gè)正規(guī)化的數(shù)據(jù)庫環(huán)境中, 我們常會(huì)碰到這款情形: 所需的資料并不是放在同一個(gè)資料表中, 在這個(gè)時(shí)候, 你就要用到 Join
當(dāng)然 Join 如何將不同的數(shù)據(jù)庫的資料結(jié)合, 還要看你如何使用它, 一共有四種不同的 Join 的方式, 在這篇文章中我們將為你介紹 Inner Join 及 Outer Join 以及其應(yīng)用
Inner Join
Inner Join 應(yīng)該是最常用的 Join 方式, 它只會(huì)傳回符合 Join 規(guī)則的紀(jì)錄, 還是先來看看語法
Select <要選擇的字段> From <主要資料表>
<Join 方式> <次要資料表> [On <Join 規(guī)則>]
現(xiàn)在我們利用 MS SQL 內(nèi)建的北風(fēng)數(shù)據(jù)庫來實(shí)際練習(xí)一下! 想多了解 MS SQL 的內(nèi)建數(shù)據(jù)庫, 你可以看看 SQL Server 的內(nèi)建數(shù)據(jù)庫 這篇文章
請(qǐng)打開 QA (Query Analyzer), 為了使用北風(fēng)數(shù)據(jù)庫, 請(qǐng)先執(zhí)行 Use Northwind, 然后執(zhí)行
Select ProductId, ProductName, SupplierId From Products
從 Products 產(chǎn)品資料表中取出三個(gè)字段, 分別是產(chǎn)品代碼, 產(chǎn)品名稱, 供貨商代碼, 但查詢出來的結(jié)果保證讓你的老板很不滿意, 因?yàn)楣┴浬檀a對(duì)于人類實(shí)在是無蝦米意義, 這個(gè)時(shí)候 Join 就可以幫上忙了, 藉由 Join Suppliers 這個(gè)資料表我們便可以查詢到供貨商名稱
Select ProductId, ProductName, Suppliers.SupplierId
From Products
Inner Join Suppliers
Products.Suppliers = Suppliers.SupplierId
這款的查詢結(jié)果是不是卡清楚呢! Inner Join 的主要精神就是 exclusive , 叫它做排他性吧! 就是講 Join 規(guī)則不相符的資料就會(huì)被排除掉, 譬如講在 Product 中有一項(xiàng)產(chǎn)品的供貨商代碼 (SupplierId), 沒有出現(xiàn)在 Suppliers 資料表中, 那么這筆記錄便會(huì)被排除掉
Outer Join
這款的 Join 方式是一般人比較少用到的, 甚至有些 SQL 的管理者也從未用過, 這真是一件悲哀的代志, 因?yàn)樯朴?Outer Join 是可以簡(jiǎn)化一些查詢的工作的, 先來看看 Outer Join 的語法
Select <要查詢的字段> From <Left 資料表>
<Left | Right> [Outer] Join <Right 資料表> On <Join 規(guī)則>
語法中的 Outer 是可以省略的, 例如你可以用 Left Join 或是 Right Join, 在本質(zhì)上, Outer Join 是 inclusive, 叫它做包容性吧! 不同于 Inner Join 的排他性, 因此在 Left Outer Join 的查詢結(jié)果會(huì)包含所有 Left 資料表的資料, 顛倒過來講, Right Outer Join 的查詢就會(huì)包含所有 Right 資料表的資料, 接下來我們還是來做些實(shí)際操作, 仍然是使用北風(fēng)數(shù)據(jù)庫, 但要先做一些小小的修改, 才能達(dá)到我們要的結(jié)果
首先要拿掉 Products 資料表的 Foreign Key, 否則沒有法度在 Products 資料表新增一筆 SupplierId 沒有對(duì)映到 Suppliers 資料表的紀(jì)錄, 要知影一個(gè)資料表的 Constraint 你可以執(zhí)行 SQL 內(nèi)建的 sp_helpconstraint , 在 QA 執(zhí)行
sp_helpconstraint Products
接下來刪除 FK_Products_Suppliers 這個(gè) Foreign Key
Alter Table Products
Drop Constraint FK_Products_Suppliers
再來新增一筆紀(jì)錄于 Products 資料表, SupplierId 使用 50 是因?yàn)樗]有對(duì)映到 Suppliers 資料表中的記錄
Insert Into Products (ProductName,SupplierId,CategoryId)
values ('Test Product','50','1')
現(xiàn)在我們?cè)賵?zhí)行頭前的查詢, 只是將 Inner Join 改為 Left Outer Join
Select ProductId, ProductName, Suppliers.SupplierId
From Products
Left Outer Join Suppliers
Products.Suppliers = Suppliers.SupplierId
比較一下兩種 Join 方式的查詢結(jié)果, 你應(yīng)該就會(huì)知影其中的差別!
再來看看 Right Outer Join, 請(qǐng)新增下底這筆記錄
Insert Into Suppliers (CompanyName)
values ('LearnASP')
現(xiàn)在請(qǐng)使用 Right Out Join 來作查詢, 比較看看查詢的結(jié)果和 Inner Join 有什么不同!
尋找不相符紀(jì)錄
這里我們來看看如何使用 Out Join 來找不相符紀(jì)錄, 可能是有子紀(jì)錄卻沒有父紀(jì)錄或是顛倒過來
Select Suppliers.CompanyName From Products
Right Join Suppliers
On Products.SupplierId = Suppliers.SupplierId
Where Products.SupplierId is Null
執(zhí)行結(jié)果你會(huì)找到一筆資料為 LearnASP, 該筆供貨商資料存在, 但基本上已經(jīng)沒有產(chǎn)品是來自這個(gè)供貨商, 想象一下如果不用 Outer Join 你要怎么以一個(gè) SQL 指令完成同一查詢結(jié)果! 知道 Outer Join 的好用了吧! 再執(zhí)行
Select Products.ProductName
From Products
Left Join Suppliers
On Products.SupplierId = Suppliers.SupplierId
Where Suppliers.SupplierId is Null
這個(gè)查詢結(jié)果你會(huì)發(fā)現(xiàn) Test Product 這項(xiàng)產(chǎn)品竟然找不到供貨商的資料!