數(shù)據(jù)庫(kù)中join的用法
數(shù)據(jù)庫(kù)中join的用法的用法你知道嗎?下面小編就跟你們?cè)敿?xì)介紹下數(shù)據(jù)庫(kù)中join的用法的用法,希望對(duì)你們有用。
數(shù)據(jù)庫(kù)中join的用法的用法如下:
一、join的用法
內(nèi)連接、外連接
示例用表:
雇員表(Employee)
LastNameDepartmentID
Rafferty31
Jones33
Steinberg33
Robinson34
Smith34
JasperNULL
部門(mén)表(Department)
DepartmentID部門(mén)
31銷售部
33工程部
34書(shū)記
35市場(chǎng)部
1、內(nèi)連接:相等連接、自然連接、交叉連接
1)、顯式的內(nèi)連接與隱式連接(inner join == join )
顯示連接:SELECT * from employee join department on employee.DepartmentID = department.DepartmentID
等價(jià)于:
隱式連接:SELECT * from employee,department WHERE employee.DepartmentID = department.DepartmentID
注:當(dāng)DepartmentID不匹配,就不會(huì)往結(jié)果表中生成任何數(shù)據(jù)。
2)、相等連接
提供了一種可選的簡(jiǎn)短符號(hào)去表達(dá)相等連接,它使用 USING 關(guān)鍵字。
SELECT * from employee join department using (DepartmentID)
注:與顯式連接不同在于:DepartmentID只顯示一列
3)、自然連接
比相等連接的進(jìn)一步特例化。兩表做自然連接時(shí),兩表中的所有名稱相同的列都將被比較,這是隱式的。
自然連接得到的結(jié)果表中,兩表中名稱相同的列只出現(xiàn)一次.
select * from employee natural join department
注:在 Oracle 里用 JOIN USING 或 NATURAL JOIN 時(shí),如果兩表共有的列的名稱前加上某表名作為前綴,
則會(huì)報(bào)編譯錯(cuò)誤: "ORA-25154: column part of USING clause cannot have qualifier"
或 "ORA-25155: column used in NATURAL join cannot have qualifier".
?。?交叉連接(又稱笛卡爾連接)
如果 A 和 B 是兩個(gè)集合,它們的交叉連接就記為: A × B.
顯示連接:
select * from employee cross join department
等價(jià)于
隱式連接:
select * from employee,department
?。?、外連接
并不要求連接的兩表的每一條記錄在對(duì)方表中都一條匹配的記錄。
1)左連接(left outer join == left join)
若A表與B表左連接,A表對(duì)就的B表沒(méi)有匹配,連接操作也會(huì)返回一條記錄,對(duì)應(yīng)值為NULL。
如:
Jaspernull null null
Jones3333工程部
Rafferty3131銷售部
Robinson3434書(shū)記
Smith3434書(shū)記
Steinberg3333工程部
若A表對(duì)應(yīng)B表中有多行,則左表會(huì)復(fù)制和右表匹配行一樣的數(shù)量,并組合生成連接結(jié)果。
如:select * from department left join employee on employee.departmentId = department.departmentId
31銷售部Rafferty31
33工程部Jones33
33工程部Steinberg33
34書(shū)記Robinson34
34書(shū)記Smith34
35市場(chǎng)部nullnull
2)、右連接(right outer join == right join)
與左連接同(略)
3)、全連接(full outer join ==full join)
是左右外連接的并集. 連接表包含被連接的表的所有記錄, 如果缺少匹配的記錄, 即以 NULL 填充。
select * from employee full outer join department on employee.departmentId = department.departmentId
注:一些數(shù)據(jù)庫(kù)系統(tǒng)(如 MySQL)并不直接支持全連接, 但它們可以通過(guò)左右外連接的并集(參: union)來(lái)模擬實(shí)現(xiàn).
和上面等價(jià)的實(shí)例:
select * from employee left join department on employee.departmentId = department.departmentId
union all
select * from employee right join department on employee.departmentId = department.departmentId
注:SQLite 不支持右連接。