欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL SERVER遞歸查詢的實現(xiàn)

 更新時間:2024年01月03日 11:19:07   作者:MoFe1  
本文主要介紹了SQL SERVER遞歸查詢的實現(xiàn),遞歸查詢是通過CTE來實現(xiàn),具有一定的參考價值,感興趣的可以了解一下

 有示例數(shù)據(jù),表名為SYS_Department

iddepartmentNameparentIdremarkisEnablestaffId
2總經(jīng)理1總經(jīng)理1
3賬務(wù)部2賬務(wù)部11006
4技術(shù)部2技術(shù)部11004
9產(chǎn)品部2產(chǎn)品部11005
10市場部2市場部1
11人事部2人事部11013
5測試部4測試部11002
6開發(fā)部4開發(fā)部11003
7設(shè)計部4設(shè)計部1
8物聯(lián)部4物聯(lián)部1
12JAVA一部6JAVA一部11009
13JAVA二部6JAVA二部1
14.NET部6.NET部11008
15前端部6前端部1

遞歸查詢原理

SQL Server中的遞歸查詢是通過CTE(表表達(dá)式)來實現(xiàn)。至少包含兩個查詢,第一個查詢?yōu)槎c成員,定點成員只是一個返回有效表的查詢,用于遞歸的基礎(chǔ)或定位點;第二個查詢被稱為遞歸成員,使該查詢稱為遞歸成員的是對CTE名稱的遞歸引用是觸發(fā)。在邏輯上可以將CTE名稱的內(nèi)部應(yīng)用理解為前一個查詢的結(jié)果集。

遞歸查詢語法

with 子查詢名稱 查詢字段列表 as --查詢字段列表輸入格式為([查詢字段名1],[查詢字段名2],...),也可用*代替,需要注意的是此處的查詢字段列表中的字段與下方內(nèi)容中定點成員與遞歸成員查詢字段列表內(nèi)容需一致
( 
--定點成員
select 查詢字段列表 from 查詢表名 where 查詢條件 
union all 
--遞歸成員
select 查詢字段列表 from 查詢表名 a inner join 子查詢名稱 on 遞歸條件 ) 
select 顯示字段名 from 子查詢名稱

已示例數(shù)據(jù)為例

--查詢1
--通過根節(jié)點向下查找該根節(jié)點下的子節(jié)點
with temp([id],[departmentName],[parentId])  as --temp([id],[departmentName])指定temp結(jié)果集中的列,如設(shè)置需包含聯(lián)表條件
( select [id],[departmentName],[parentId] from SYS_Department where id = 2
union all select a.[id],a.[departmentName],a.[parentId] from SYS_Department a inner join temp on a.[parentId] = temp.[id] ) 
select  [id],[departmentName] from temp

--查詢2
--通過子節(jié)點向上查找該子節(jié)點的根節(jié)點
with temp([id],[departmentName],[parentId])  as 
( select [id],[departmentName],[parentId] from SYS_Department where id = 2
union all select a.[id],a.[departmentName],a.[parentId] from SYS_Department a inner join temp on
--調(diào)換查詢字段
a.[id] = temp.[parentId] ) 
select  [id],[departmentName] from temp

查詢2查詢結(jié)果

mysql示例 使用recursive關(guān)鍵字

--Mysql 查詢時聯(lián)表條件與SQL SERVER相反
--父查子
with recursive temp(Id,DepartmentName,ParentId) as 
(select Id,DepartmentName,ParentId from SYS_Department  where id = 2
union all 
select a.Id,a.DepartmentName,a.ParentId from SYS_Department a inner join temp on a.ParentId  = temp.Id)
select * from temp

--子查父
with recursive temp(Id,DepartmentName,ParentId) as 
(select Id,DepartmentName,ParentId from SYS_Department  where id = 2
union all 
select a.Id,a.DepartmentName,a.ParentId from SYS_Department a inner join temp on a.Id = temp.ParentId )
select * from temp

不指定查詢字段列表

--查詢1
--不指定子查詢查詢字段列表
with temp as 
(
--查詢表中所有字段 
select * from SYS_Department where id = 2
union all 
--查詢主表中所有字段(根據(jù)UNION ALL語法需與定點成員查詢字段保持一致)
select a.* from SYS_Department a inner join temp on a.[parentId] = temp.[id] ) 
--顯示表中所有字段
select * from temp

--查詢2
--不指定子查詢查詢字段列表
with temp as 
(
--查詢表中所有字段 
select * from SYS_Department where id = 2
union all 
--查詢主表中所有字段(根據(jù)UNION ALL語法需與定點成員查詢字段保持一致)
select a.* from SYS_Department a inner join temp on a.[parentId] = temp.[id] ) 
--顯示表中id字段
select id from temp

查詢結(jié)果1

查詢結(jié)果2

 總結(jié):

以樹的概念去理解查詢原理可能相對比較容易一些,以下是以結(jié)果反推的個人理解:

關(guān)鍵字:

定點成員(示例語句中:select * from SYS_Department where id = 2)

遞歸成員(示例語句中:select a.* from SYS_Department a inner join temp on a.[parentId] = temp.[id])

拼接(使用UNION ALL)

SQL遞歸查詢是以定點成員為查詢起始點(即語句中的select * from SYS_Department where id = 2),第一次查詢時取到定點成員的子節(jié)點(即示例數(shù)據(jù)中parentid=2的數(shù)據(jù),可以將查詢起始點理解為樹的根節(jié)點),通過特定的順序遍歷取到的子節(jié)點(遍歷順序經(jīng)測試為倒序遍歷,即先遍歷id=4的數(shù)據(jù),再遍歷id=3的數(shù)據(jù)),當(dāng)該子節(jié)點下存在數(shù)據(jù)時(即已select a.* from SYS_Department a inner join temp on a.[parentId] = temp.[id]的查詢結(jié)果不為NULL時)顯示數(shù)據(jù)并繼續(xù)遍歷該節(jié)點,直至查詢導(dǎo)的結(jié)果為空或達(dá)到最大的迭代次數(shù)(默認(rèn)為100),最終將所有節(jié)點遍歷完成并將遍歷的結(jié)果以UNION ALL語句拼接輸出結(jié)果集。

以示例數(shù)據(jù)為例,反推的查詢流程以及數(shù)據(jù)如圖所示:

 1.第一次遞歸時(目前無法確定開始執(zhí)行的順序是先執(zhí)行定點成員語句后遞歸還是獲取到子節(jié)點后遞歸,猜測順序為執(zhí)行完定點成員SQL后進(jìn)行第一次遞歸)獲取拼接下圖中

2.遞歸遍歷通過定點成員獲取到的子節(jié)點,先遍歷id=11的節(jié)點,但該節(jié)點下獲取的數(shù)據(jù)為空所以不拼接任何數(shù)據(jù),id=10和9的同理,當(dāng)遍歷到id為4的節(jié)點時,獲取拼接下圖數(shù)據(jù)

 3.遞歸遍歷上圖中獲取到的節(jié)點,先遍歷id=8的節(jié)點,但該節(jié)點下獲取的數(shù)據(jù)為空所以不拼接任何數(shù)據(jù),id=7和5的同理,當(dāng)遍歷到id為6的節(jié)點時,獲取拼接下圖數(shù)據(jù)

 4.遞歸遍歷上圖中獲取到的節(jié)點,先遍歷id=15的節(jié)點,但該節(jié)點下獲取的數(shù)據(jù)為空所以不拼接任何數(shù)據(jù),id=14,13,12的節(jié)點同理

5.此時以id=4的節(jié)點為根節(jié)點的所有節(jié)點已遍歷完成,繼續(xù)遞歸遍歷通過定點成員獲取到的子節(jié)點,即遍歷id=3的節(jié)點,但該節(jié)點下獲取的數(shù)據(jù)為空所以不拼接任何數(shù)據(jù),最終顯示結(jié)果集如下圖所示

 原文參考:

WITH common_table_expression (Transact-SQL) | Microsoft Docs

Recursive Queries Using Common Table Expressions | Microsoft Docs

思路借鑒:SQL中的遞歸的用法_SQL數(shù)據(jù)庫開發(fā)的博客-CSDN博客

到此這篇關(guān)于SQL SERVER遞歸查詢的實現(xiàn)的文章就介紹到這了,更多相關(guān)SQL 遞歸查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 復(fù)制原理與實踐應(yīng)用詳解

    mysql 復(fù)制原理與實踐應(yīng)用詳解

    這篇文章主要介紹了mysql 復(fù)制原理與實踐應(yīng)用,結(jié)合實例形式詳細(xì)分析了MySQL數(shù)據(jù)庫復(fù)制功能的原理、操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2020-02-02
  • Mysql賬戶管理原理與實現(xiàn)方法詳解

    Mysql賬戶管理原理與實現(xiàn)方法詳解

    這篇文章主要介紹了Mysql賬戶管理原理與實現(xiàn)方法,結(jié)合實例形式詳細(xì)分析了mysql賬戶管理的原理、操作技巧、相關(guān)問題解決方法與注意事項,需要的朋友可以參考下
    2020-01-01
  • MySQL數(shù)據(jù)庫使用規(guī)范總結(jié)

    MySQL數(shù)據(jù)庫使用規(guī)范總結(jié)

    本篇文章給大家詳細(xì)分類總結(jié)了數(shù)據(jù)庫相關(guān)規(guī)范,幫助大家發(fā)揮出數(shù)據(jù)庫的性能,感興趣的朋友可以了解下
    2020-08-08
  • 淺析MySQL數(shù)據(jù)的導(dǎo)出與導(dǎo)入知識點

    淺析MySQL數(shù)據(jù)的導(dǎo)出與導(dǎo)入知識點

    在本文里我們給大家分享了關(guān)于MySQL數(shù)據(jù)的導(dǎo)出與導(dǎo)入的相關(guān)實例和知識點內(nèi)容,需要的朋友們跟著學(xué)習(xí)下。
    2019-03-03
  • mysql server is running with the --skip-grant-tables option

    mysql server is running with the --skip-grant-tables option

    今天在mysql中新建數(shù)據(jù)庫提示The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement,原來是數(shù)據(jù)中配置的--skip-grant-tables,這樣安全就降低了,這個一般當(dāng)忘記root密碼的時候需要這樣操作
    2017-07-07
  • PHP5 mysqli的prepare準(zhǔn)備語句使用說明

    PHP5 mysqli的prepare準(zhǔn)備語句使用說明

    mysqli對prepare的支持對于大訪問量的網(wǎng)站是很有好處的,它極大地降低了系統(tǒng)開銷,而且保證了創(chuàng)建查詢的穩(wěn)定性和安全性.prepare準(zhǔn)備語句分為綁定參數(shù)和綁定結(jié)果
    2012-12-12
  • 解析MYSQL顯示表信息的方法

    解析MYSQL顯示表信息的方法

    本篇文章是對MYSQL顯示表信息的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • mysql中sum float類型使用小數(shù)點的方法

    mysql中sum float類型使用小數(shù)點的方法

    使用sum示和時如果是float類型的數(shù)據(jù)就會出現(xiàn)小數(shù)點了,那么要如何解決這個問題,下面介紹二種方法
    2013-11-11
  • Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql

    Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql

    這篇文章主要介紹了Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql數(shù)據(jù)庫的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • MySQL索引操作命令詳解

    MySQL索引操作命令詳解

    這篇文章主要介紹了MySQL索引操作命令詳解,需要的朋友可以參考下
    2017-01-01

最新評論