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

歡迎訪問 生活随笔!

生活随笔

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

数据库

图解SQL Join用法

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

詳情請看:http://www.codinghorror.com/blog/2007/10/a-visual-explanation-of-sql-joins.html

通過 文氏圖?Venn diagrams?解釋了SQL的Join。簡單易懂,轉過來收藏當箱底貨了。

假設有兩張表。

  • Table A?是左邊的表。
  • Table B?是右邊的表。

其各有四條記錄,其中有兩條記錄是相同的,如下所示:

id name id name -- ---- -- ---- 1 Pirate 1 Rutabaga 2 Monkey 2 Pirate 3 Ninja 3 Darth Vader 4 Spaghetti 4 Ninja

下面讓我們來看看不同的Join會產生什么樣的結果。

SELECT * FROM TableA INNER JOIN TableB ON TableA.name = TableB.nameid name id name -- ---- -- ---- 1 Pirate 2 Pirate 3 Ninja 4 Ninja

Inner join
產生的結果集中,是A和B的交集。

SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.nameid name id name -- ---- -- ---- 1 Pirate 2 Pirate 2 Monkey null null 3 Ninja 4 Ninja 4 Spaghetti null null null null 1 Rutabaga null null 3 Darth Vader

Full outer join?產生A和B的并集。但是需要注意的是,對于沒有匹配的記錄,則會以null做為值。

SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.nameid name id name -- ---- -- ---- 1 Pirate 2 Pirate 2 Monkey null null 3 Ninja 4 Ninja 4 Spaghetti null null

Left outer join?產生表A的完全集,而B表中匹配的則有值,沒有匹配的則以null值取代。

SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.name = TableB.name WHERE TableB.id IS null id name id name -- ---- -- ---- 2 Monkey null null 4 Spaghetti null null

產生在A表中有而在B表中沒有的集合。

SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.name = TableB.name WHERE TableA.id IS null OR TableB.id IS null id name id name -- ---- -- ---- 2 Monkey null null 4 Spaghetti null null null null 1 Rutabaga null null 3 Darth Vader

產生A表和B表都沒有出現的數據集。

還需要注意的是我們還有一個是“交差集”?cross join, 這種Join沒有辦法用文式圖表示,因為其就是把表A和表B的數據進行一個N*M的組合,即笛卡爾積。表達式如下:

SELECT * FROM TableA CROSS JOIN TableB

這個笛卡爾乘積會產生?4 x 4 = 16 條記錄,一般來說,我們很少用到這個語法。但是我們得小心,如果不是使用嵌套的select語句,一般系統都會產生笛卡爾乘積然再做過濾。這是對于性能來說是非常危險的,尤其是表很大的時候。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

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

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