sql左連接左外連接
Ⅰ sql中的左外連接和+號的用法
SQL中的左外連接和+號的用法
Oracle 左連接、右連接、全外連接、(+)號作用
Oracle 外連接
(1)左外連接 (左邊的表不加限制)
(2)右外連接(右邊的表不加限制)
(3)全外連接(左右兩表都不加限制)
外連接(Outer Join)
outer join則會返回每個滿足第一個(頂端)輸入與第二個(底端)輸入的聯接的行。它還返回任何在第二個輸入中沒有匹配行的第一個輸入中的行。外連接分為三種: 左外連接,右外連接,全外連接。 對應SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我們省略outer 這個關鍵字。 寫成:LEFT/RIGHT/FULL JOIN。
在左外連接和右外連接時都會以一張表為基表,該表的內容會全部顯示,然後加上兩張表匹配的內容。 如果基表的數據在另一張表沒有記錄。 那麼在相關聯的結果集行中列顯示為空值(NULL)。
對於外連接, 也可以使用「(+) 」來表示。 關於使用(+)的一些注意事項:
1.(+)操作符只能出現在where子句中,並且不能與outer join語法同時使用。
2. 當使用(+)操作符執行外連接時,如果在where子句中包含有多個條件,則必須在所有條件中都包含(+)操作符
3.(+)操作符只適用於列,而不能用在表達式上。
4.(+)操作符不能與or和in操作符一起使用。
5.(+)操作符只能用於實現左外連接和右外連接,而不能用於實現完全外連接。
在做實驗之前,我們先將dave表和bl里加一些不同的數據。 以方便測試。
SQL> select * from bl;
ID NAME
---------- ----------
1 dave
2 bl
3 big bird
4 exc
9 懷寧
SQL> select * from dave;
ID NAME
---------- ----------
8 安慶
1 dave
2 bl
1 bl
2 dave
3 dba
4 sf-express
5 dmm
2.1 左外連接(Left outer join/ left join)
left join是以左表的記錄為基礎的,示例中Dave可以看成左表,BL可以看成右表,它的結果集是Dave表中的數據,在加上Dave表和BL表匹配的數據。換句話說,左表(Dave)的記錄將會全部表示出來,而右表(BL)只會顯示符合搜索條件的記錄。BL表記錄不足的地方均為NULL.
示例:
SQL> select * from dave a left join bl b on a.id = b.id;
ID NAME ID NAME
--------- ---------- ---------- ----------
1 bl 1 dave
1 dave 1 dave
2 dave 2 bl
2 bl 2 bl
3 dba 3 big bird
4 sf-express 4 exc
5 dmm -- 此處B表為null,因為沒有匹配到
8 安慶 -- 此處B表為null,因為沒有匹配到
SQL> select * from dave a left outer join bl b on a.id = b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
1 bl 1 dave
1 dave 1 dave
2 dave 2 bl
2 bl 2 bl
3 dba 3 big bird
4 sf-express 4 exc
5 dmm
8 安慶
用(+)來實現, 這個+號可以這樣來理解: + 表示補充,即哪個表有加號,這個表就是匹配表。所以加號寫在右表,左表就是全部顯示,故是左連接。
SQL> Select * from dave a,bl b where a.id=b.id(+); -- 注意: 用(+) 就要用關鍵字where
ID NAME ID NAME
---------- ---------- ---------- ----------
1 bl 1 dave
1 dave 1 dave
2 dave 2 bl
2 bl 2 bl
3 dba 3 big bird
4 sf-express 4 exc
5 dmm
8 安慶
2.2 右外連接(right outer join/ right join)
和left join的結果剛好相反,是以右表(BL)為基礎的, 顯示BL表的所以記錄,在加上Dave和BL 匹配的結果。 Dave表不足的地方用NULL填充.
示例:
SQL> select * from dave a right join bl b on a.id = b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
1 dave 1 dave
2 bl 2 bl
1 bl 1 dave
2 dave 2 bl
3 dba 3 big bird
4 sf-express 4 exc
9 懷寧 --此處左表不足用Null 填充
已選擇7行。
SQL> select * from dave a right outer join bl b on a.id = b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
1 dave 1 dave
2 bl 2 bl
1 bl 1 dave
2 dave 2 bl
3 dba 3 big bird
4 sf-express 4 exc
9 懷寧 --此處左表不足用Null 填充
已選擇7行。
用(+)來實現, 這個+號可以這樣來理解: + 表示補充,即哪個表有加號,這個表就是匹配表。所以加號寫在左表,右表就是全部顯示,故是右連接。
SQL> Select * from dave a,bl b where a.id(+)=b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
1 dave 1 dave
2 bl 2 bl
1 bl 1 dave
2 dave 2 bl
3 dba 3 big bird
4 sf-express 4 exc
9 懷寧
2.3 全外連接(full outer join/ full join)
左表和右表都不做限制,所有的記錄都顯示,兩表不足的地方用null 填充。 全外連接不支持(+)這種寫法。
示例:
SQL> select * from dave a full join bl b on a.id = b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
8 安慶
1 dave 1 dave
2 bl 2 bl
1 bl 1 dave
2 dave 2 bl
3 dba 3 big bird
4 sf-express 4 exc
5 dmm
9 懷寧
已選擇9行。
SQL> select * from dave a full outer join bl b on a.id = b.id;
ID NAME ID NAME
---------- ---------- ---------- ----------
8 安慶
1 dave 1 dave
2 bl 2 bl
1 bl 1 dave
2 dave 2 bl
3 dba 3 big bird
4 sf-express 4 exc
5 dmm
最初由 ghc_x 發布
[B]有兩個表T1和T2,兩個表除了主鍵索引外均無其他索引,這兩個表由T1.F1(主鍵),T2.F2(主鍵)進行左連接,SQL語句有兩種寫法:
1. SELECT * FROM T1,T2 WHERE T1.F1=T2.F2(+)
2. SELECT * FROM T1 LEFT JOIN T2 ON T1.F1=T2.F2
當查看1的執行計劃時發現T1為全表掃描,T2為索引掃描。
當查看2的執行計劃時發現兩個表均為全表掃描。
有人知道這是為什麼嗎? [/B]
我一直以來也是認為這兩種寫法是一樣的,沒想到樓主特意去看了它們的執行計劃,而且發現了它們的不同,這使得我比較驚訝。
按照書上的講法,這兩種寫法是沒有什麼區別的,後一種寫法只不過是前一種寫法的新版本。
為什麼兩者的執行計劃會不一樣呢?
我仔細看了一下兩者的執行計劃,發現了為什麼後一種要兩個表都全表 掃描,而前一個表有一個索引掃描。
原來前者選擇的優化器是RULE,而後者選擇的優化器是CBO的ALL ROWS。
不過,似乎要後者的效率高。
1. SELECT /*+RULE*/ * FROM T1,T2 WHERE T1.F1=T2.F2(+)
2. SELECT /*+RULE*/ * FROM T1 LEFT JOIN T2 ON T1.F1=T2.F2
這樣再看下執行計劃吧
Ⅱ sql server 什麼是全外連接,左外連接,右外連接,它們的區別又是什麼
全外連接就是左外連接和右外連接的結合。
左外連接和右外連接的區別如下:
1、數據集合上的區別
(1)左外連接:是A與B的交集,然後連接A的所有數據。
(2)右外連接:是A與B的交集,然後連接B的所有數據。
2、計算方法上的區別
(1)左外連接:計算方法是,A左連接B記錄=表3的公用記錄集C +表A的記錄集A1。
(2)右外連接:計算方法是,A右連接B記錄=圖3公共部分記錄集C +表B記錄集B1。
3、語法上的區別
(1)左外連接:SELECT * FROM aleft OUTER JOIN bON a.`ageId` = b.`id`。
(2)右外連接:SELECT * FROM aright OUTER JOIN bON a.`ageId` = b.`id`。
Ⅲ SQL:左連接,右連接是什麼概念啊
SQL中左連接和右連接都屬於外連接。
左連接是LEFT JOIN或LEFT OUTER JOIN,左向外聯接的結果集包括 LEFT OUTER子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值。
右連接是RIGHT JOIN 或 RIGHT OUTER JOIN,右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。
舉例:要查詢所有學生的選課情況,包括已經選課的和還沒有選課的學生,查詢語句為SELECT學生表.學號,姓名,班級,課程號,成績 FROM學生表LEFT OUTER JOIN選課表ON學生表.學號=選課表.學號,左外連接查詢中左端表中的所有元組的信息都得到了保留。
(3)sql左連接左外連接擴展閱讀
連接查詢是關系資料庫中最主要的查詢,主要包括內連接、外連接和交叉連接等。聯接條件可在FROM或WHERE子句中指定,建議在FROM子句中指定聯接條件。WHERE和HAVING子句也可以包含搜索條件,以進一步篩選聯接條件所選的行。
內連接是INNERJOIN簡寫成JOIN,是典型的聯接運算,使用像 = 或 <> 之類的比較運算符。包括相等聯接和自然聯接。內聯接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。
外聯接除了左右連接外,還有完整外部聯接FULL JOIN 或 FULL OUTER JOIN,完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。
交叉聯接返回左表中的所有行,左表中的每一行與右表中的所有行組合。交叉聯接也稱作笛卡爾積。FROM 子句中的表或視圖可通過內聯接或完整外部聯接按任意順序指定;但是,用左或右向外聯接指定表或視圖時,表或視圖的順序很重要。
Ⅳ SQL中的左連接與右連接有什麼區別,點解返回值會不同
1、意思不一樣
左連接:只要左邊表中有記錄,數據就能檢索出來,而右邊有的記錄必要在左邊表中有的記錄才能被檢索出來。
右連接:右連接是只要右邊表中有記錄,數據就能檢索出來。
2、空值不一樣
左連接是已左邊表中的數據為基準,若左表有數據右表沒有數據,則顯示左表中的數據右表中的數據顯示為空。
右聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。
左連接實例
在左外連接和右外連接時都會以一張表為基表,該表的內容會全部顯示,然後加上兩張表匹配的內容。如果基表的數據在另一張表沒有記錄。那麼在相關聯的結果集行中列顯示為空值(NULL)。
對於外連接, 也可以使用「(+) 」來表示。 關於使用(+)的一些注意事項:
1、(+)操作符只能出現在where子句中,並且不能與outer join語法同時使用。
2、當使用(+)操作符執行外連接時,如果在where子句中包含有多個條件,則必須在所有條件中都包含(+)操作符。
以上內容參考:網路-外連接
Ⅳ sql左連接 右連接 內連接 外連接都是什麼
內外連接:
內連接:取的兩個表的(有能連接的欄位),的交集,即欄位相同的。利用內連接可獲取兩表的公共部分的記錄,
select * from A,B where A.Aid=B.Bnameid
與 Select * from A JOIN B ON A.Aid=B.Bnameid的運行結果是一樣的。
外連接:左右連接。
外連接分為兩種,一種是左連接(Left JOIN)和右連接(Right JOIN)
(1)左連接(Left JOIN):即圖3公共部分記錄集C+表A記錄集A1。語句如下: select * from A Left JOIN B ON A.Aid=B.Bnameid A的欄位全有,查詢出來在結果集的左邊。
(2)右連接(Right JOIN):即圖3公共部分記錄集C+表B記錄集B1。語句如下:select * from A Right JOIN B ON A.Aid=B.Bnameid
左右連接的sql語句實例:(+),中間函數NVL給空值賦值。
sql="select name,id,area_name from (select a.name,a.id,NVL(c.area_name,'未分配') area_name "+
"from department a, area_department b,area_table c "+
"where a.id= b.f_branch_id(+) "+
"and b.area_code= c.area_code(+)) d where 1=1 ";
Ⅵ sql左外連接和右外連接的區別
一、數據集合不同
1、左外連接:是A和B的交集再並上A的所有數據。
2、右外連接:是A和B的交集再並上B的所有數據。
二、語法不同
1、左外連接:SELECT *FROM aLEFT OUTER JOIN bON a.`ageId` = b.`id`。
2、右外連接:SELECT *FROM aright OUTER JOIN bON a.`ageId` = b.`id`。
三、運算方式不同
1、左外連接:其運算方式為:A左連接B的記錄=圖3公共部分記錄集C+表A記錄集A1。
2、右外連接:其運算方式為:A右連接B的記錄=圖3公共部分記錄集C+表B記錄集B1 。
Ⅶ sql左外連接和右外連接的區別
1、依據上的區別
①前者基於SELECT *FROM aLEFT OUTER JOIN bON a.`ageId` = b.`id`;
②後者基於SELECT *FROM aright OUTER JOIN bON a.`ageId` = b.`id`。
2、公式上的區別
①前者按照該方法來進行計算:A左連接B的記錄=公共部分記錄集C+表A記錄集A1;
②後者按照該方法來進行計算:A右連接B的記錄=公共部分記錄集C+表B記錄集B1 。
3、范圍上的區別
①前者屬於A和B的交集再並上A的所有數據;
②後者屬於A和B的交集再並上B的所有數據。
sql的其他連接類型
1、sql內連接
包括相等連接和自然連接,使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。
2、sql交叉連接
也稱作笛卡爾積,使FROM子句中的表或視圖可通過內外連接按任意順序指定。但是,用外連接指定表或視圖時,表或視圖的順序很重要。
Ⅷ SQL中的左連接與右連接,內連接有什麼區別
SQL內連接與外連接的共有3點不同:
1、兩者的分類不同:內連接分為相等連接和自然連接兩種連接方式;而外連接分為左外連接、右外連接和全外連接三種連接方式(左外連接即LEFT OUTER JOIN;右外連接即RIGHT OUTER JOIN)。
2、兩者所連接的對象表不同:內連接進行連接的兩個表是對應的相匹配的欄位完全相同的。左外連接中進行連接的兩個表會返回左邊表中的所有的行和右邊表中與之相匹配的列值,沒有相匹配的用空值代替。右外連接中進行連接的兩個表會返回右邊表中的所有的行和左邊表中與之相匹配的列值,沒有相匹配的用空值代替。
3、兩者的作用范圍不同:內連接的連接發生在一張基表內,而外連接的連接發生在兩張表之間。
註:內連接(典型的連接運算,使用像 = 或 <> 之類的比較運算符)。包括相等連接和自然連接。內連接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。
Ⅸ sql server 什麼是全外連接,左外連接,右外連接,它們的區別又是什麼
全外連接就是左外連接和右外連接的結合。
左外連接和右外連接的區別如下:
1、數據集合上的區別
(1)左外連接:是A與B的交集,然後連接A的所有數據。
(2)右外連接:是A與B的交集,然後連接B的所有數據。
2、計算方法上的區別
(1)左外連接:計算方法是,A左連接B記錄=表3的公用記錄集C +表A的記錄集A1。
(2)右外連接:計算方法是,A右連接B記錄=圖3公共部分記錄集C +表B記錄集B1。
3、語法上的區別
(1)左外連接:SELECT * FROM aleft OUTER JOIN bON a.`ageId` = b.`id`。
(2)右外連接:SELECT * FROM aright OUTER JOIN bON a.`ageId` = b.`id`。
Ⅹ sql左連接、右連接、全連接、內連接有啥區別
左(外)連接(LEFT JOIN),以左表為基準,查詢出左表所有的數據和右表中連接欄位相等的記錄,如果右表中沒有對應數據,則在左表記錄後顯示為空(NULL).如果把兩個表分別看成一個集合的話,則顯示的結果為JOIN左邊的集合。
右(外)連接(RIGHT JOIN )是以右表為基準,查詢出右表所有的數據和左表中連接欄位相等的記錄,如果左表沒有對應數據則在右表對應數據行顯示為空(NULL).如果把兩個表分別看成一個集合的話,則顯示的結果為JOIN右邊的集合。
內連接(INNER JOIN )是查詢出兩個表對應的數據,如果把兩個表分別看成一個集合的話,內連接的結果即為兩個表的交集。
全連接(FULL JOIN )將兩個表的數據全部查出來,返回左右表中所有的記錄和左右表中連接欄位相等的記錄,如果把兩個表分別看成一個集合的話,全外連接的結果即為兩個表的並集。