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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...