日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQL JOIN的用法

發布時間:2025/3/20 数据库 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL JOIN的用法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景:(血的教訓)

  非常感謝能夠有幸的去活力世紀面試,面試官非常的祥和,雖然最后沒能夠去成,但是非常的感謝,是他讓我明白了自己還有很多需要去學習,每一次的面試不是為了去證明自己有多強,能拿多少的工資,而是去檢驗自己哪些方面還有不足,需要去努力,加油,為了更好的自己......之前在公司的代碼中看到了關于一些left join的東西,但是沒有太關注這些,剛好面試的時候問到了這些,現在剛好有時間,順便的學習一遍,加強自己.......

關于sql語句中的連接(join)關鍵字,是較為常用而又不太容易理解的關鍵字,廢話就不多說了,直接進入主題,案例:

可以參照博客:http://www.cnblogs.com/yiki/archive/2007/01/04/611452.html

一、建表

新建表一 table1 ? ? ? ? ? ?新建表二 ?table2

? ? ? ? ??

一、外連接
1.概念:包括左向外聯接、右向外聯接或完整外部聯接

2.左連接:left join 或 left outer join
(1)左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值(null)。
(2)sql語句

select * from table1 left join table2 on table1.id=table2.id

-------------結果-------------

?注釋:包含table1的所有子句,根據指定條件返回table2相應的字段,不符合的以null顯示 ?不可以使用where作為條件的篩選噢,不然會報錯的

3.右連接:right join 或 right outer join
(1)右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。
(2)sql語句

select * from table1 right join table2 on table1.id=table2.id

-------------結果-------------

?

注釋:包含table2的所有子句,根據指定條件返回table1相應的字段,不符合的以null顯示

4.完整外部聯接:full join 或 full outer join?
(1)完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。
(2)sql語句

select * from table1 full join table2 on table1.id=table2.id

我的數據庫5.5中竟然不支持full join 所以我用了另外一種來代替

select * from table1 left join table2 on table1.id=table2.id UNION select * from table1 RIGHT JOIN table2 on table1.id=table2.id

-------------結果-------------

注釋:返回左右連接的和(見上左、右連接)

二、內連接
1.概念:內聯接是用比較運算符比較要聯接列的值的聯接

2.內連接:join 或 inner join

3.sql語句

select * from table1 join table2 on table1.id=table2.id

-------------結果-------------

注釋:只返回符合條件的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

-------------結果-------------

注釋:返回3*3=9條記錄,即笛卡爾積

4.等價(與下列執行效果相同)
A:select * from table1,table2 ? ? ?

?

轉載于:https://www.cnblogs.com/antonyhubei/p/5600096.html

總結

以上是生活随笔為你收集整理的SQL JOIN的用法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。