內連接、左外連接、右外連接、交叉連接區別

来源:http://www.cnblogs.com/hd976521/archive/2017/06/16/7026287.html
-Advertisement-
Play Games

內連接、左外連接、右外連接、交叉連接區別 http://blog.csdn.net/cnham/archive/2008/06/25/2584936.aspx 在之前,我對MSSQL中的內連接和外連接所得出的數據集不是很清楚。這幾天重新溫習了一下SQL的書本,現在的思路應該是很清楚了,現在把自己的理 ...


內連接、左外連接、右外連接、交叉連接區別

  http://blog.csdn.net/cnham/archive/2008/06/25/2584936.aspx 
在之前,我對MSSQL中的內連接和外連接所得出的數據集不是很清楚。這幾天重新溫習了一下SQL的書本,現在的思路應該是很清楚了,現在把自己的理解發出來給大家溫習下。希望和我一樣對SQL的連接語句不太理解的朋友能夠有所幫助。(發這麼菜的教程,各位大大們別笑話偶了,呵:D ) 有兩個表A和表B。表A結構如下: Aid:int;標識種子,主鍵,自增ID Aname:varchar 數據情況,即用select * from A出來的記錄情況如下圖1所示:
   

圖1:A表數據
表B結構如下: Bid:int;標識種子,主鍵,自增ID Bnameid:int 數據情況,即用select * from B出來的記錄情況如下圖2所示:
   

圖2:B表數據
為了把Bid和Aid加以區分,不讓大家有誤解,所以把Bid的起始種子設置為100。有SQL基本知識的人都知道,兩個表要做連接,就必須有個連接欄位,從上表中的數據可以看出,在A表中的Aid和B表中的Bnameid就是兩個連接欄位。下圖3說明瞭連接的所有記錄集之間的關係:  
圖3:連接關係圖 
現在我們對內連接和外連接一一講解。 1.內連接:利用內連接可獲取兩表的公共部分的記錄,即圖3的記錄集C 語句如下:Select * from A JOIN B ON A.Aid=B.Bnameid 運行結果如下圖4所示:其實select * from A,B where A.Aid=B.Bnameid與Select * from A JOIN B ON A.Aid=B.Bnameid的運行結果是一樣的。
     
圖4:內連接數據

 2.外連接:外連接分為兩種,一種是左連接(Left JOIN)和右連接(Right JOIN)
 (1)左連接(Left JOIN):即圖3公共部分記錄集C+表A記錄集A1。
 語句如下:select * from A Left JOIN B ON A.Aid=B.Bnameid 
運行結果如下圖5所示:
   

圖5:左連接數據     

說明:在語句中,A在B的左邊,並且是Left Join,所以其運算方式為:A左連接B的記錄=圖3公共部分記錄集C+表A記錄集A1
在圖3中即記錄集C中的存在的Aid為:2 3 6 7 8 
圖1中即表A所有記錄集A中存在的Aid為:1 2 3 4 5 6 7 8 9  
表A記錄集A1中存在的Aid=(圖1中即A表中所有Aid)-(圖3中即記錄集C中存在的Aid),最終得出為:1 4 5 9  
由此得出圖5中A左連接B的記錄=圖3公共部分記錄集C+表A記錄集A1, 最終得出的結果圖5中可以看出Bnameid及Bid非NULL的記錄都為圖3公共部分記錄集C中的記錄;Bnameid及Bid為NULL的Aid為1 4 5 9的四筆記錄就是表A記錄集A1中存在的Aid。
 
(2)右連接(Right JOIN):即圖3公共部分記錄集C+表B記錄集B1。

語句如下:select * from A Right JOIN B ON A.Aid=B.Bnameid   運行結果如下圖6所示:
 

 

 


圖6:右連接數據 
說明: 在語句中,A在B的左邊,並且是Right Join,所以其運算方式為:A右連接B的記錄=圖3公共部分記錄集C+表B記錄集B1 
在圖3中即記錄集C中的存在的Aid為:2 3 6 7 8  
圖2中即表B所有記錄集B中存在的Bnameid為:2 3 6 7 8 11  
表B記錄集B1中存在的Bnameid=(圖2中即B表中所有Bnameid)-(圖3中即記錄集C中存在的Aid),最終得出為:11  
由此得出圖6中A右連接B的記錄=圖3公共部分記錄集C+表B記錄集B1, 最終得出的結果圖6中可以看出Aid及Aname非NULL的記錄都為圖3公共部分記錄集C中的記錄;Aid及Aname為NULL的Aid為11的記錄就是表B記錄集B1中存在的Bnameid。    

交叉連接:兩張表聯合沒有條件情況下,條數 = 圖1 * 圖2

 

 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • description 在開發過程中, 往往會有很多的model來裝載屬性. 而在開發期間經常會進行調試查看model里的屬性值是否正確. 那麼問題來了, 在objective-c里使用NSLog("%@",model)這行代碼列印出來的卻是model的地址. 不是我們所想要的結果~! 看圖: 那麼 ...
  • 登錄的業務邏輯{ http:是短連接. 伺服器如何判斷當前用戶是否登錄? // 1. 如果是即時通信類:長連接. // 如何保證伺服器跟客戶端保持長連接狀態? // "心跳包" 用來檢測用戶是否線上!用來做長連接! http:短連接使用token 機制來驗證用戶安全性 // token 值: 登錄令 ...
  • 有些時候我們使用Service的時需要採用隱私啟動的方式,但是Android 5.0一齣來後,其中有個特性就是Service Intent must be explitict,也就是說從Lollipop開始,service服務必須採用顯示方式啟動。 而android源碼是這樣寫的(源碼位置:sdk/ ...
  • 轉自 http://www.jianshu.com/p/6588c69b42cf ...
  • 基於AS的採用Kotlin語言開發的動畫漸入的弧形菜單(附java代碼),具體看效果... ...
  • NSCharacterSet 對於string處理,在IOS生態系統中經常用到且用錯的重要組成部分:NSCharacterSet。下麵詳解一下: NSCharacterSet ,以及它的可變版本NSMutableCharacterSet,用面向對象的方式來表示一組Unicode字元。它經常與NSSt ...
  • google 在Android 5.0推出 Camera2 這個類,用於替換 Camera,但是Camera2要求android sdk 最低版本為 minSdkVersion = 21 (5.0系統),所以Camera2 還不能完全替換 Camera,在相容低版本的時候,還是需要兩者一起協同開發。 ...
  • 本文內容來源於Redis作者博文,Redis作者說,他看到的所有針對Redis的討論中,對Redis持久化的誤解是最大的,於是他寫了一篇長文來對Redis的持久化進行了系統性的論述。文章非常長,也很值得一看,NoSQLFan將主要內容簡述成本文。 什麼是持久化,簡單來講就是將數據放到斷電後數據不會丟 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...