資料庫查詢內連線,外連線,各種查

2021-06-02 17:15:37 字數 2625 閱讀 7071

一、外連線

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...