oracle中l(wèi)eft join和right join的區(qū)別淺談
通俗的講:
A left join B 的連接的記錄數(shù)與A表的記錄數(shù)同
A right join B 的連接的記錄數(shù)與B表的記錄數(shù)同
A left join B 等價(jià)B right join A
table A:
Field_K, Field_A
1 a
3 b
4 c
table B:
Field_K, Field_B
1 x
2 y
4 z
select a.Field_K, a.Field_A, b.Field_K, b.Field_B
from a left join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
3 b NULL NULL
4 c 4 z
select a.Field_K, a.Field_A, b.Field_K, b.Field_B
from a right join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
NULL NULL 2 y
4 c 4 z --
舉個(gè)例子:
假設(shè)a表和b表的數(shù)據(jù)是這樣的。
a b
id name id stock
1 a 1 15
2 b 2 50
3 c
select * from a inner join b on a.id=b.id
這個(gè)語(yǔ)法是連接查詢中的內(nèi)連接,它產(chǎn)生的結(jié)果是
兩個(gè)表相匹配的記錄出現(xiàn)在結(jié)果列表中。
根據(jù)上面的表,出現(xiàn)的結(jié)果是這樣的
a.id name b.id stock
1 a 1 15
2 b 2 50
----------------------------
select * from a,b where a.id=b.id
這個(gè)語(yǔ)法是內(nèi)連接的另外一種寫(xiě)法,其執(zhí)行結(jié)果與inner join 一樣
--------------------------------
select * from a left/right join b on a.id=b.id
這個(gè)是外連接語(yǔ)法中的左外連接或右外連接
如果是左外連接的話,它將顯示a表的所有記錄,
select a.*,b.* from a left join b on a.id=b.id
查詢的結(jié)果是這樣的:
a.id name b.id stock
1 a 1 15
2 b 2 50
3 c null null
--------------------------------------------
如果是右外連接的話,它將顯示b表的所有記錄,
select a.*,b.* from a right join b on a.id=b.id
查詢的結(jié)果是這樣的:
a.id name b.id stock
1 a 1 15
2 b 2 50
--
select a.*,b.* from a left join b on a.k = b.k
select a.*,b.* from a left outer join b on a.k =b.k
----------上面兩種一樣left join是left outer join的簡(jiǎn)寫(xiě)
select a.*,b.* from a left inner join b on a.k = b.k
沒(méi)有這種寫(xiě)法,錯(cuò)誤的語(yǔ)句.
相關(guān)文章
Oracle表空間的創(chuàng)建、使用、重命名與刪除方法
表空間是Oracle數(shù)據(jù)庫(kù)中的一個(gè)重要概念,它是一組物理文件,用于存儲(chǔ)數(shù)據(jù)庫(kù)對(duì)象,如表、索引等,在使用Oracle數(shù)據(jù)庫(kù)時(shí),通常需要?jiǎng)?chuàng)建表空間來(lái)存放數(shù)據(jù),本文介紹了Oracle表空間的創(chuàng)建、使用、重命名與刪除方法2024-03-03Oracle誤刪除表數(shù)據(jù)后的數(shù)據(jù)恢復(fù)詳解
這篇文章主要介紹了Oracle誤刪除表數(shù)據(jù)后的數(shù)據(jù)恢復(fù)詳解,需要的朋友可以參考下2015-08-08Oracle中直方圖對(duì)執(zhí)行計(jì)劃的影響詳解
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)中直方圖對(duì)執(zhí)行計(jì)劃的影響的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09linux自動(dòng)運(yùn)行rman增量備份腳本
這篇文章主要介紹了linux自動(dòng)運(yùn)行rman增量備份腳本,實(shí)現(xiàn)周日和周三凌晨1:00執(zhí)行0級(jí)全庫(kù)備份,周一、二、四、五、六凌晨1:30執(zhí)行增量備份,需要的朋友可以參考下2014-03-03ORACLE多條件統(tǒng)計(jì)查詢的簡(jiǎn)單方法
這篇文章主要介紹了ORACLE多條件統(tǒng)計(jì)查詢的簡(jiǎn)單方法,具有一定參考價(jià)值。這里給大家分享下,希望對(duì)大家有所幫助。2017-10-10- Oracle系統(tǒng),即是以O(shè)racle關(guān)系數(shù)據(jù)庫(kù)為數(shù)據(jù)存儲(chǔ)和管理作為構(gòu)架基礎(chǔ),構(gòu)建出的數(shù)據(jù)庫(kù)管理系統(tǒng)。世界第一個(gè)支持SQL語(yǔ)言的商業(yè)數(shù)據(jù)庫(kù),定位于高端工作站,以及作為服務(wù)器的小型計(jì)算機(jī),Oracle公司的整個(gè)產(chǎn)品線包括數(shù)據(jù)庫(kù)服務(wù)器、企業(yè)商務(wù)應(yīng)用套件、應(yīng)用開(kāi)發(fā)和決策支持工具2014-08-08