SQLServer之多表聯合查詢

来源:https://www.cnblogs.com/vuenote/archive/2018/12/15/10124649.html
-Advertisement-
Play Games

多表聯合查詢簡介 定義:連接查詢是關係型資料庫最主要的查詢,通過連接運算符可以實現多個表連接數據查詢。 分類:內連接,外連接,全外連接。 內連接 定義 內聯接使用比較運算符根據每個表的通用列中的值匹配兩個表中的行。 語法 select 表1.*,表2.* from 表1 as a [wtih(鎖)] ...


多表聯合查詢簡介

定義:連接查詢是關係型資料庫最主要的查詢,通過連接運算符可以實現多個表連接數據查詢。

分類:內連接,外連接,全外連接。

內連接

定義

內聯接使用比較運算符根據每個表的通用列中的值匹配兩個表中的行。

語法

select 表1.*,表2.* from 表1 as a [wtih(鎖)] inner join 表2 as b [wtih(鎖)] on a.值 {= | != } b.值 [條件1] [where 條件] [group by 條件] [having 條件] [order by 條件];

語法註釋

{}:大括弧內的值必選一個,例如:選擇=號。

[]:索引符號的值表示是可添加也可不添加的,例如:選擇不添加[條件1]。

[條件1]:[條件1]=[and | or ] [a.值=b.值 | a.值!=b.值 | a.值=值 | a.值!=值 | b.值=值 | b.值!=值],例如:and a.值=b值,或者,or a.值等於b.值。

[where 條件]:where後跟表中數據的篩選條件,例如:where a.值=1。

[group by 條件]:group by後面跟分組條件,可以跟一個或者多個分組條件,例如:group by a.值,b.值。

[having 條件]:having後邊主要是篩選group by條件分組後的結果,後面可以跟一個或者多個條件,例如:select max(a.id),min(b.name) from A as a inner join B as b on a.id=b.id group by a.id,b.name having a,id>1 and b.name=1。

[order by 條件]:order by後面跟排序條件,可以根據一個值或者多個值排序,例如:根據多個值排序,select a.* from A as a inner join B as b on a.id=b.id order by a.值 asc,b.值 desc。

示例:A表內連接B表,使用A表中的數據逐行匹配B表的中數據,匹配成功則返回,匹配失敗則不返回值,匹配成功一共返回五行數據,where條件篩選返回五行數據,group by條件篩選返回兩行數據,having條件篩選返回兩行數據,order by條件篩選3大於1,則3在第一行,1在第二行。

外連接

分類

left outer join(左外連接)和right outer join(右連接)。

左外連接

定義

從表(右表)中的數據逐條匹配主表(左表)中的數據,如果匹配,如果右表匹配一行或者多行則將右表匹配值一行或者多行追加到左表匹配行輸出到結果集,如果無匹配,NULL值追加到左表不匹配行輸出到結果集。

語法

select 表1.*,表2.* from 表1 as a [wtih(鎖)] left [outer] join 表2 as b [wtih(鎖)] on a.值 {= | != } b.值 [條件1] [where 條件] [group by 條件] [having 條件] [order by 條件];

語法註釋

{}:大括弧內的值必選一個,例如:選擇=號。

[]:索引符號的值表示是可添加也可不添加的,例如:選擇不添加[條件1]。

[條件1]:[條件1]=[and | or ] [a.值=b.值 | a.值!=b.值 | a.值=值 | a.值!=值 | b.值=值 | b.值!=值],例如:and a.值=b值,或者,or a.值等於b.值。

[where 條件]:where後跟表中數據的篩選條件,例如:where a.值=1。

[group by 條件]:group by後面跟分組條件,可以跟一個或者多個分組條件,例如:group by a.值,b.值。

[having 條件]:having後邊主要是篩選group by條件分組後的結果,後面可以跟一個或者多個條件,例如:select max(a.id),min(b.name) from A as a left outer join B as b on a.id=b.id group by a.id,b.name having a,id>1 and b.name=1。

[order by 條件]:order by後面跟排序條件,可以根據一個值或者多個值排序,例如:根據多個值排序,select a.* from A as a left outer join B as b on a.id=b.id order by a.值 asc,b.值 desc。

示例:A表左外連接B表,B表中數據逐行取出與A表中數據匹配,右表取出第一行數據1與A表逐行匹配,匹配到兩行,將B表數據1追加到A表數據行輸出到結果集,同理剩餘的數據3和1匹配到三行數據,共匹配到五行數據輸出,A中存在數據2與B表無匹配行,則將NULL值追加到A表數據2行輸出,匹配的結果集和不匹配的結果集共七行數據輸出到結果集。(where條件篩選後輸出七行數據,group by條件篩選後會輸出三行數據,having篩選後會輸出三行數據,order by條件篩選後則會按照數據從大到小排列),依次顯示不加篩選條件和添加所有篩選條件的結果。

右外連接

定義

從表(左表)中的數據逐條匹配主表(右表)中的數據,如果匹配,如果左表匹配一行或者多行則將左表匹配值一行或者多行追加到右表匹配行輸出到結果集,如果無匹配,NULL值追加到右表不匹配行輸出到結果集。

語法

select 表1.*,表2.* from 表1 as a [wtih(鎖)] right [outer] join 表2 as b [wtih(鎖)] on a.值 {= | != } b.值 [條件1] [where 條件] [group by 條件] [having 條件] [order by 條件];

語法註釋

{}:大括弧內的值必選一個,例如:選擇=號。

[]:索引符號的值表示是可添加也可不添加的,例如:選擇不添加[條件1]。

[條件1]:[條件1]=[and | or ] [a.值=b.值 | a.值!=b.值 | a.值=值 | a.值!=值 | b.值=值 | b.值!=值],例如:and a.值=b值,或者,or a.值等於b.值。

[where 條件]:where後跟表中數據的篩選條件,例如:where a.值=1。

[group by 條件]:group by後面跟分組條件,可以跟一個或者多個分組條件,例如:group by a.值,b.值。

[having 條件]:having後邊主要是篩選group by條件分組後的結果,後面可以跟一個或者多個條件,例如:select max(a.id),min(b.name) from A as a right outer join B as b on a.id=b.id group by a.id,b.name having a,id>1 and b.name=1。

[order by 條件]:order by後面跟排序條件,可以根據一個值或者多個值排序,例如:根據多個值排序,select a.* from A as a right outer join B as b on a.id=b.id order by a.值 asc,b.值 desc。

示例:A表右外連接B表,A表中數據逐行取出與B表中數據匹配,左表取出第一行數據1與B表逐行匹配,匹配到兩行,將A表數據1追加到B表數據行輸出到結果集,同理剩餘的數據1和3匹配到三行數據,共匹配到五行數據輸出,A中存在數據2與B表無匹配行,自動過濾掉並不添加輸出,B表數據全部匹配完成,不匹配的結果集為零行,匹配的結果集和不匹配的結果集共五行數據輸出到結果集。(where條件篩選後輸出五行數據,group by條件篩選後會輸出兩行數據,having篩選後會輸出兩行數據,order by條件篩選後則會按照數據從大到小排列),依次顯示不加篩選條件和添加所有篩選條件的結果。

全外連接

定義

全外連接又稱為完全外連接,該連接查詢方式返回兩個連接中所有的記錄數據。根據匹配條件,如果滿足匹配條件時,則返回匹配的一行或者多行數據;如果不滿足匹配條件時,同樣返回數據,但在相應的列中填入NULL,全外連接返回的結果集中包含了兩個完全表的所有數據。全外連接關鍵字FULL OUTER JOIN。

語法

select 表1.*,表2.* from 表1 as a [wtih(鎖)] full [outer] join 表2 as b [wtih(鎖)] on a.值 { = | != } b.值 [條件1] [where 條件] [group by 條件] [having 條件] [order by 條件];

語法註釋

{}:大括弧內的值必選一個,例如:選擇=號。

[]:索引符號的值表示是可添加也可不添加的,例如:選擇不添加[條件1]。

[條件1]:[條件1]=[and | or ] [a.值=b.值 | a.值!=b.值 | a.值=值 | a.值!=值 | b.值=值 | b.值!=值],例如:and a.值=b值,或者or a.值等於b.值。

[where 條件]:where後跟表中數據的篩選條件,例如:where a.值=1。

[group by 條件]:group by後面跟分組條件,可以跟一個或者多個分組條件,例如:group by a.值,b.值。

[having 條件]:having後邊主要是篩選group by條件分組後的結果,後面可以跟一個或者多個條件,例如:select max(a.id),min(b.name) from A as a full outer join B as b on a.id=b.id group by a.id,b.name having a,id>1 and b.name=1。

[order by 條件]:order by後面跟排序條件,可以根據一個值或者多個值排序,例如:根據多個值排序,select a.* from A as a full outer join B as b on a.id=b.id order by a.值 asc,b.值 desc。

示例:全外連接A表與B表,首先輸出所有符合條件的數據,A表中數據逐行取出和B表中數據逐行匹配,存在1和3的數據匹配行,匹配成功輸出5行數據,然後輸出不符合條件的行,A中存在2行不符合條件的值,B表數據全部匹配成功無不符合條件的值,返回A中不符合條件的值並將其它列值置為NULL輸出2行數據,總共輸出5加2共七行數據。

 


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

-Advertisement-
Play Games
更多相關文章
  • 使用NPOI 操作Excel 個人使用的電腦基本預設安裝Excel 操作起來 調用Excel的組件便可.如果是一臺伺服器.沒有安裝Excel,也就無法調用Excel組件. 在此推薦第三方插件.NPOI 支持XLS(2007)和XLSX(2012)讀寫. 讀: 寫: 消息在Rabbit中.A接觸Rab ...
  • 事件系統用途廣泛,對處理玩家數據有很大幫助(玩家金幣,經驗,等級),讓數據多次調用,降低耦合 在unity中應用(以玩家金幣發生變化來演示); 1).註冊監聽 2).移出監聽 3).金幣發生變化的時候,通知每個界面 操作: 1.將Event三個腳本導入工程中; 2.寫一個腳本,PlayerInfor ...
  • 在我們Winform開發中,往往需要涉及到附件的統一管理,因此我傾向於把它們獨立出來作為一個附件管理模塊,這樣各個模塊都可以使用這個附件管理模塊,更好的實現模塊重用的目的。在涉及附件管理的場景中,一個數據記錄可能對應多個附件組場景,每個附件組則涉及附件多個文件,往往這些附件可能放置的目錄會有所不同,... ...
  • 2.1 控制器的角色 MVC模式中的控制器(Controller)主要負責響應用戶的輸入,冰球在響應時修改模型(Model)。通過這種方式,MVC模式中的控制器主要關註的是應用程式流、輸入數據的處理,以及對相關視圖(View)輸出數據的提供。 URL首先告知陸游機制去實例化哪個控制器,調用哪個操作方 ...
  • C# winfrom 寫的一個搜索助手,可以按照標題和內容搜索,指定目錄後,遍歷搜索文件和子目,現在只寫了支持.DOC.DOCX.XLS.XLSX.PPT.PPTX.PDF.HTML.HTM.TXT等格式的文件搜索,讀取execl 內容使用的是NPOI組件,doc,html,txt 格式的使用Str ...
  • 我利用網路上的windows 10 純凈版來進行安裝windows 10 鏡像的時候,發現很多的windows 的服務都是不能用的。比如啟動/刪除 windows 功能就是不能用的,會出現如下信息: 發現出現了:“參照的程式集沒有安裝在系統上” 的錯誤,這應該是,你不小心安裝上精簡版系統造成的,某些 ...
  • 前幾節里,通過幾個案例,分析了各種常見的 CPU 性能問題。通過這些,相信對 CPU 的性能分析已經不再陌生和恐懼,起碼有了基本的思路,也瞭解了不少 CPU 性能的分析工 具。 不過,我猜你可能也碰到了一個我曾有過的困惑: CPU 的性能指標那麼多,CPU 性能分析工具 也是一抓一大把,如果離開專欄 ...
  • 控制台命令 運行redis # ./bin/redis-server ./redis.conf 搜索redis是否運行 # ps -ef | grep -i redis 關閉redis # ./bin/redis-cli shutdown 進入redis # ./bin/redis-cli 127. ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...