首頁 資料庫 mysql教程 SqlServer之连接

SqlServer之连接

Jun 07, 2016 pm 03:51 PM
server sql sqlserver 我們 連接

在sql server中,我们经常能用到连接,今天总结一下连接的基础知识。 连接的分类: 交叉连接 CROSS JOIN 内连接 INNER JOIN 外连接{左外连接 LEFT [OUTER] JOIN ;右外连接 RIGHT [OUTER] JOIN ;全外连接 full [outer] join } 自连接 以下通过例子来了解各

在sql server中,我们经常能用到连接,今天总结一下连接的基础知识。
连接的分类:

  • 交叉连接CROSS JOIN
  • 内连接INNER JOIN
  • 外连接{左外连接LEFT [OUTER] JOIN ;右外连接RIGHT [OUTER] JOIN;全外连接full [outer] join}
  • 自连接

以下通过例子来了解各个连接的异同点:

有两张表Teacher表和Course表:

SqlServer之连接

SqlServer之连接

交叉连接:

1.如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积;

<span>select</span> <span>*</span> <span>from</span> Course <span>cross</span> <span>join</span> Teacher
登入後複製

结果为:

SqlServer之连接

由此结果可知,它的结果与 SELECT * FROM Course,Teacher 的结果相同。

2.如果有WHERE子句的话,往往会先生成两个表行数乘积的数据表然后才根据WHERE条件从中选择。

<span>1. select</span> <span>*</span> <span>from</span> Course,Teacher <span>where</span> Course.T#<span>=</span>Teacher.T#
<span>2. select</span> <span>*</span> <span>from</span> Course <span>cross</span> <span>join</span> Teacher <span>where</span> Course.T#<span>=</span>Teacher.T#<strong><span><span>  (</span><span>注:cross join后加条件只能用where,不能用on)</span></span></strong>
<span>3. select</span> <span>*</span> <span>from</span> Course <span>inner</span> <span>join</span> Teacher <span>on</span> Course.T#<span>=</span>Teacher.T#
登入後複製

结果为:

SqlServer之连接

一般情况下,在效率上,Where可能具有和Inner join一样的效率,但是,在多表连接时,我们并不推荐使用where语句。
所以如果可以选择,我们最好使用语句3,有时使用Join语句可以帮助检查语句中的无效或者误写的关联条件。

内连接

内连接表示两边表同时符合条件的组合,就相当于普通的CROSS JOIN,只是格式不一样,
INNER JOIN在后面有一个ON子句(相当于WHERE)的搜索条件,用于过滤返回的行。
内连接没有笛卡尔积那么复杂要先生成行数乘积的数据表,所以内连接的效率要高于笛卡尔积的交叉连接。

外连接

指定条件的内连接,仅仅返回符合连接条件的条目。
外连接则不同,返回的结果不仅包含符合连接条件的行,而且包括左表(左外连接时), 右表(右连接时)或者两边连接(全外连接时)的所有数据行。

1)左外连接LEFT [OUTER] JOIN
显示符合条件的数据行,同时显示左边数据表不符合条件的数据行,右边没有对应的条目显示NULL

<span>select</span> <span>*</span> <span>from</span> Course <span>left</span> <span>outer</span> <span>join</span> Teacher <span>on</span> Course.T#<span>=</span>Teacher.T#
登入後複製

结果为:

SqlServer之连接

2)右外连接RIGHT [OUTER] JOIN
显示符合条件的数据行,同时显示右边数据表不符合条件的数据行,左边没有对应的条目显示NULL

<span>select</span> <span>*</span> <span>from</span> Course <span>right</span> <span>outer</span> <span>join</span> Teacher <span>on</span> Course.T#<span>=</span>Teacher.T#
登入後複製
结果为:

SqlServer之连接



3)全外连接full [outer] join

显示符合条件的数据行,同时显示左右不符合条件的数据行,相应的左右两边显示NULL,即显示左连接、右连接和内连接的并集。

<span>select</span> <span>*</span> <span>from</span> Course <span>full</span> <span>outer</span> <span>join</span> Teacher <span>on</span> Course.T#<span>=</span>Teacher.T#
登入後複製

结果为:

SqlServer之连接

自连接

其实,在Sql Server中,我们还经常用到一种连接——自连接。
通过以下的例子,来了解自连接:
表树形结构表tb_TestTreeView

SqlServer之连接

解决问题: 树形层次结构显示
/*
 这是一个地区表,里面存放了地区名及其所属上级地区,假设现在需要查询出各地区及其所属上级地区。
*/

自连接的方法1:

<span>select</span> <span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
  (<span>select</span> <span>[</span><span>Name</span><span>]</span> <span>from</span> tb_TestTreeView <span>as</span> a
    <span>where</span> a.ID <span>=</span> b.Parent ) <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> b
登入後複製

自连接的方法2:

<span>select</span> a.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
       b.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> a
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> b
     <span>on</span> a.Parent <span>=</span> b.ID
登入後複製

结果为:

SqlServer之连接

自连接三级(左联接):

SqlServer之连接

<span>select</span> a.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
       b.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>,
       c.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> a
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> b
     <span>on</span> a.Parent <span>=</span> b.ID 
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> c
     <span>on</span> b.parent<span>=</span>c.id
登入後複製

SqlServer之连接

结果为:

SqlServer之连接

自连接三级(内联接):

SqlServer之连接

<span>select</span> a.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
       b.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>,
       c.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> a
<span>inner</span> <span>join</span> tb_TestTreeView <span>as</span> b
     <span>on</span> a.Parent <span>=</span> b.ID 
<span>inner</span> <span>join</span> tb_TestTreeView <span>as</span> c
     <span>on</span> b.parent<span>=</span>c.id
登入後複製

SqlServer之连接

结果为:SqlServer之连接

自连接四级(左链接):

SqlServer之连接

<span>select</span> a.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
       b.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>,
       c.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上级地区名</span><span>'</span>,
       d.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> a
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> b
     <span>on</span> a.Parent <span>=</span> b.ID 
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> c
     <span>on</span> b.parent<span>=</span>c.id
<span>left</span> <span>join</span> tb_TestTreeView <span>as</span> d
     <span>on</span> c.parent<span>=</span>d.id
登入後複製

SqlServer之连接

结果为:


SqlServer之连接



自连接四级(内链接):

SqlServer之连接

<span>select</span> a.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>地区名</span><span>'</span>,
       b.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上级地区名</span><span>'</span>,
       c.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上级地区名</span><span>'</span>,
       d.<span>[</span><span>Name</span><span>]</span> <span>as</span> <span>'</span><span>上上上级地区名</span><span>'</span>
<span>from</span> tb_TestTreeView <span>as</span> a
<span>inner</span> <span>join</span> tb_TestTreeView <span>as</span> b
     <span>on</span> a.Parent <span>=</span> b.ID
<span>inner</span> <span>join</span> tb_TestTreeView <span>as</span> c
     <span>on</span> b.Parent <span>=</span> c.ID
<span>inner</span> <span>join</span> tb_TestTreeView <span>as</span> d
     <span>on</span> c.Parent <span>=</span> d.ID
登入後複製

SqlServer之连接

结果为:

SqlServer之连接



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

sqlserver怎麼匯入mdf文件 sqlserver怎麼匯入mdf文件 Apr 08, 2024 am 11:41 AM

匯入步驟如下:將 MDF 檔案複製到 SQL Server 的資料目錄(通常為 C:\Program Files\Microsoft SQL Server\MSSQL\DATA)。在 SQL Server Management Studio(SSMS)中,開啟資料庫並選擇「附加」。點選“新增”按鈕,選擇 MDF 檔案。確認資料庫名稱,點選確定按鈕即可。

sqlserver資料庫中已存在名為的物件怎麼解決 sqlserver資料庫中已存在名為的物件怎麼解決 Apr 05, 2024 pm 09:42 PM

對於 SQL Server 資料庫中已存在同名對象,需要採取下列步驟:確認物件類型(表格、檢視、預存程序)。如果物件為空,可使用 IF NOT EXISTS 跳過建立。如果物件有數據,使用不同名稱或修改結構。使用 DROP 刪除現有物件(謹慎操作,建議備份)。檢查架構更改,確保沒有引用刪除或重新命名的物件。

Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

怎麼查看sqlserver連接埠號 怎麼查看sqlserver連接埠號 Apr 05, 2024 pm 09:57 PM

若要查看 SQL Server 連接埠號碼:開啟 SSMS,連線到伺服器。在物件資源管理器中找到伺服器名稱,右鍵單擊它,然後選擇“屬性”。在「連線」標籤中,查看「TCP 連接埠」欄位。

sqlserver服務無法啟動怎麼辦 sqlserver服務無法啟動怎麼辦 Apr 05, 2024 pm 10:00 PM

當 SQL Server 服務無法啟動時,可採取下列步驟解決:檢查錯誤日誌以確定根本原因。確保服務帳戶具有啟動服務的權限。檢查依賴項服務是否正在執行。禁用防毒軟體。修復 SQL Server 安裝。如果修復不起作用,重新安裝 SQL Server。

sqlserver誤刪資料庫怎麼恢復 sqlserver誤刪資料庫怎麼恢復 Apr 05, 2024 pm 10:39 PM

若誤刪 SQL Server 資料庫,可採取下列步驟還原:停止資料庫活動;備份日誌檔案;檢查資料庫日誌;復原選項:從備份還原;從交易日誌還原;使用 DBCC CHECKDB;使用第三方工具。請定期備份資料庫並啟用交易日誌以防止資料遺失。

sqlserver資料庫在哪裡 sqlserver資料庫在哪裡 Apr 05, 2024 pm 08:21 PM

SQL Server 資料庫檔案通常儲存在下列預設位置:Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data可透過修改資料庫檔案路徑設定來自訂資料庫檔案位置。

sqlserver安裝失敗怎麼樣刪除乾淨 sqlserver安裝失敗怎麼樣刪除乾淨 Apr 05, 2024 pm 11:27 PM

如果 SQL Server 安裝失敗,可透過下列步驟清理:解除安裝 SQL Server刪除註冊表項刪除檔案和資料夾重新啟動計算機

See all articles