SQL Server 樹形表非循環(huán)遞歸查詢的實例詳解
很多人可能想要查詢整個樹形表關(guān)聯(lián)的內(nèi)容都會通過循環(huán)遞歸來查...事實上在微軟在SQL2005或以上版本就能用別的語法進(jìn)行查詢,下面是示例。
--通過子節(jié)點查詢父節(jié)點 WITH TREE AS( SELECT * FROM Areas WHERE id = 6 -- 要查詢的子 id UNION ALL SELECT Areas.* FROM Areas, TREE WHERE TREE.PId = Areas.Id ) SELECT Area FROM TREE --通過父節(jié)點查詢子節(jié)點 WITH TREE AS( SELECT * FROM Areas WHERE id = 7 -- 要查詢的子 id UNION ALL SELECT Areas.* FROM Areas, TREE WHERE TREE.Id = Areas.PId ) SELECT Area FROM TREE
通過子節(jié)點查詢父節(jié)點查詢結(jié)果為:

修改代碼為
--通過子節(jié)點查詢父節(jié)點 declare @area varchar(8000); WITH TREE AS( SELECT * FROM Areas WHERE id = 6 -- 要查詢的子 id UNION ALL SELECT Areas.* FROM Areas, TREE WHERE TREE.PId = Areas.Id ) select @area=isnull(@area,'')+Area from Tree order by id select Area= @area
則結(jié)果為:中國北京市豐臺區(qū)
根據(jù)以上可以將這段代碼封裝為一個存儲過程
-----存儲過程,遞歸獲取樹形地區(qū)表字符串 if exists (select * from sysobjects where name='SP_GetAreaStr') drop proc SP_GetAreaStr go create procedure SP_GetAreaStr @id int as declare @area varchar(8000) begin WITH TREE AS( SELECT * FROM Areas WHERE id = @id -- 要查詢的子 id UNION ALL SELECT Areas.* FROM Areas, TREE WHERE TREE.PId = Areas.Id ) select @area=isnull(@area,'')+Area from Tree order by id select Area= @area end go --exec sp_helptext 'SP_GetAreaStr' --go exec SP_GetAreaStr 28 go
查詢結(jié)果:中國安徽省宿州市靈璧縣
所用表結(jié)構(gòu):

部分?jǐn)?shù)據(jù):

以上所述是小編給大家介紹的SQL Server 樹形表非循環(huán)遞歸查詢的實例詳解的相關(guān)知識,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
- sql server遞歸子節(jié)點、父節(jié)點sql查詢表結(jié)構(gòu)的實例
- 使用SqlServer CTE遞歸查詢處理樹、圖和層次結(jié)構(gòu)
- 使用SQLSERVER 2005/2008 遞歸CTE查詢樹型結(jié)構(gòu)的方法
- SQLSERVER2005 中樹形數(shù)據(jù)的遞歸查詢
- SQLserver2008使用表達(dá)式遞歸查詢
- 高效的SQLSERVER分頁查詢(推薦)
- SQL Server SQL高級查詢語句小結(jié)
- Sql server2005 優(yōu)化查詢速度50個方法小結(jié)
- SQLserver 實現(xiàn)分組統(tǒng)計查詢(按月、小時分組)
- sqlserver 模糊查詢常用方法
- sql server實現(xiàn)遞歸查詢的方法示例
相關(guān)文章
大數(shù)據(jù)量高并發(fā)的數(shù)據(jù)庫優(yōu)化詳解
這篇文章主要介紹了大數(shù)據(jù)量高并發(fā)的數(shù)據(jù)庫優(yōu)化,需要的朋友可以參考下2015-08-08
sql數(shù)據(jù)庫不能直接用instr函數(shù)
sql數(shù)據(jù)庫不能直接用instr函數(shù)...2007-01-01
SQL Server 2016 CTP2.3 的關(guān)鍵特性總結(jié)
SQL Server2016 CTP2.2是微軟數(shù)據(jù)平臺歷史上邁出最大的一步,更快的事務(wù)處理和查詢、任何設(shè)備更深入的洞察力、更先進(jìn)的分析能力、全新安全技術(shù)和全新的混合云場景,本文給大家介紹SQL Server 2016 CTP2.3 的關(guān)鍵特性總結(jié),需要的朋友可以參考下2015-09-09
SQL Server定時收縮數(shù)據(jù)庫日志為指定大小的示例代碼
SQL Server提供了DBCC SHRINKFILE 命令來清理事務(wù)日志文件,該命令可以縮小指定文件的大小,并釋放磁盤空間,本文給大家介紹了SQL Server如何定時收縮數(shù)據(jù)庫日志為指定大小,需要的朋友可以參考下2024-03-03
CMD命令操作MSSQL2005數(shù)據(jù)庫(命令整理)
創(chuàng)建數(shù)據(jù)庫、創(chuàng)建用戶、修改數(shù)據(jù)的所有者、設(shè)置READ_COMMITTED_SNAPSHOT以及備份、日志扥等等,感興趣的朋友可以參考下2013-05-05
SQL?Server主鍵與外鍵設(shè)置以及相關(guān)理解
在數(shù)據(jù)庫的學(xué)習(xí)中對于一個表的主鍵和外鍵的認(rèn)識是非常重要的,下面這篇文章主要給大家介紹了關(guān)于SQL?Server主鍵與外鍵設(shè)置以及相關(guān)理解的相關(guān)資料,需要的朋友可以參考下2022-10-10

