一、外連線
1.概念:包括左向外聯接、右向外聯接或完整外部聯接
2.左連線:left join 或 left outer join
(1)左向外聯接的結果集包括 left outer 子句中指定的左表的所有
行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有
匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值
(null)。
(2)sql語句
select * from table1 left join table2 on
table1.id=table2.id
-------------結果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
4wangnullnull
------------------------------
注釋:包含table1的所有子句,根據指定條件返回table2相應的字
段,不符合的以null顯示
3.右連線:right join 或 right outer join
(1)右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如
果右表的某行在左表中沒有匹配行,則將為左表返回空值。
(2)sql語句
select * from table1 right join table2 on
table1.id=table2.id
-------------結果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
nullnull370
------------------------------
注釋:包含table2的所有子句,根據指定條件返回table1相應的字
段,不符合的以null顯示
4.完整外部聯接:full join 或 full outer join
(1)完整外部聯接返回左表和右表中的所有行。當某行在另乙個表中
沒有匹配行時,則另乙個表的選擇列表列包含空值。如果表之間有
匹配行,則整個結果集行包含基表的資料值。
(2)sql語句
select * from table1 full join table2 on
table1.id=table2.id
-------------結果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
4wangnullnull
nullnull370
------------------------------
注釋:返回左右連線的和(見上左、右連線)
二、內連線
1.概念:內聯接是用比較運算子比較要聯接列的值的聯接
2.內連線:join 或 inner join
3.sql語句
select * from table1 join table2 on table1.id=table2.id
-------------結果-------------
idnameidscore
------------------------------
1lee190
2zhang2100
------------------------------
注釋:只返回符合條件的table1和table2的列
4.等價(與下列執行效果相同)
a:select a.*,b.* from table1 a,table2 b where a.id=b.id
b:select * from table1 cross join table2 where
table1.id=table2.id (注:cross join後加條件只能用where,不
能用on)
三、交叉連線(完全)
1.概念:沒有 where 子句的交叉聯接將產生聯接所涉及的表的笛卡
爾積。第乙個表的行數乘以第二個表的行數等於笛卡爾積結果集的
大小。(table1和table2交叉連線產生3*3=9條記錄)
2.交叉連線:cross join (不帶條件where...)
3.sql語句
select * from table1 cross join table2
-------------結果-------------
idnameidscore
------------------------------
1lee190
2zhang190
4wang190
1lee2100
2zhang2100
4wang2100
1lee370
2zhang370
4wang370
------------------------------
注釋:返回3*3=9條記錄,即笛卡爾積
資料庫多表連線查詢 外連線和內連線
本文主要列舉兩張和三張表來講述多表連線查詢。新建兩張表 表1 student 截圖如下 表2 course 截圖如下 此時這樣建表只是為了演示連線sql語句,當然實際開發中我們不會這樣建表,實際開發中這兩個表會有自己不同的主鍵。一 外連線 外連線可分為 左連線 右連線 完全外連線。1 左連線 lef...
資料庫多表連線查詢 外連線和內連線
本文主要列舉兩張和三張表來講述多表連線查詢。新建兩張表 表1 student 截圖如下 www.2cto.com 表2 course 截圖如下 此時這樣建表只是為了演示連線sql語句,當然實際開發中我們不會這樣建表,實際開發中這兩個表會有自己不同的主鍵。一 外連線 外連線可分為 左連線 右連線 完全...
資料庫 連線(自然連線 外連線 內連線)
1 自然連線 只考慮那些在兩個關係模式中都出現的屬性上取值相同的元組對natural join join.using select a1,a2,an from r1 natural join r2 natural join natural join rn where p select name1,c...