SQL Server 通過with as方法查詢樹型結(jié)構(gòu)
一、with as 公用表表達(dá)式
類似VIEW,但是不并沒有創(chuàng)建對象,WITH AS 公用表表達(dá)式不創(chuàng)建對象,只能被后隨的SELECT語句,其作用:
1. 實現(xiàn)遞歸查詢(樹形結(jié)構(gòu))
2. 可以在一個語句中多次引用公用表表達(dá)式,使其更加簡潔
二、非遞歸的公共表達(dá)式
可以是定義列或自動列和select into 效果差不多
--指定列 with withTmp1 (code,cName) as ( select id,Name from ClassUnis ) select * from withTmp1 --自動列 with withTmp2 as ( select * from ClassUnis where Author = 'system' ) select * from withTmp2
三、遞歸的方式
通過UNION ALL 連接部分。通過連接自身whit as 創(chuàng)建的表達(dá)式,它的連接條件就是遞歸的條件。可以從根節(jié)點往下查找,從子節(jié)點往父節(jié)點查找。只需要顛倒一下連接條件。例如代碼中條件改為t.ID = c.ParentId即可
with tree as( --0 as Level 定義樹的層級,從0開始 select *,0 as Level from ClassUnis where ParentId is null union all --t.Level + 1每遞歸一次層級遞增 select c.*,t.Level + 1 from ClassUnis c,tree t where c.ParentId = t.ID --from ClassUnis c inner join tree t on c.ParentId = t.ID ) select * from tree where Author not like'%/%'
還能通過option(maxrecursion Number) 設(shè)置最大遞歸次數(shù)。例如上訴結(jié)果Level 最大值為2表示遞歸兩次。我們設(shè)置其值為1
with tree as( select *,0 as Level from ClassUnis where ParentId is null union all select c.*,t.Level + 1 from ClassUnis c,tree t where c.ParentId = t.ID ) select * from tree where Author not like'%/%' option(maxrecursion 1)
好了這篇文章就介紹到這了,希望能幫助到你。
上一篇:sql server日志處理不當(dāng)造成的隱患詳解
欄 目:MsSql
下一篇:詳解將DataGrip連接到MS SQL Server的方法
本文標(biāo)題:SQL Server 通過with as方法查詢樹型結(jié)構(gòu)
本文地址:http://www.jygsgssxh.com/a1/MsSql/10277.html
您可能感興趣的文章
- 01-10SQLServer存儲過程實現(xiàn)單條件分頁
- 01-10SQL Server 2012降級至2008R2的方法
- 01-10SQLServer中防止并發(fā)插入重復(fù)數(shù)據(jù)的方法詳解
- 01-10SQL Server數(shù)據(jù)庫定時自動備份
- 01-10SQL Server性能調(diào)優(yōu)之緩存
- 01-10實現(xiàn)SQL Server 原生數(shù)據(jù)從XML生成JSON數(shù)據(jù)的實例代碼
- 01-10Sql Server 死鎖的監(jiān)控分析解決思路
- 01-10SqlServer 在事務(wù)中獲得自增ID的實例代碼
- 01-10SqlServer快速檢索某個字段在哪些存儲過程中(sql 語句)
- 01-10SQLServer性能優(yōu)化--間接實現(xiàn)函數(shù)索引或者Hash索引


閱讀排行
本欄相關(guān)
- 01-10SQLServer存儲過程實現(xiàn)單條件分頁
- 01-10SQLServer中防止并發(fā)插入重復(fù)數(shù)據(jù)的方
- 01-10SQL Server 2012降級至2008R2的方法
- 01-10SQL Server性能調(diào)優(yōu)之緩存
- 01-10SQL Server數(shù)據(jù)庫定時自動備份
- 01-10Sql Server 死鎖的監(jiān)控分析解決思路
- 01-10實現(xiàn)SQL Server 原生數(shù)據(jù)從XML生成JSON數(shù)
- 01-10SqlServer快速檢索某個字段在哪些存儲
- 01-10SqlServer 在事務(wù)中獲得自增ID的實例代
- 01-10SQLServer性能優(yōu)化--間接實現(xiàn)函數(shù)索引或
隨機閱讀
- 01-10C#中split用法實例總結(jié)
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05DEDE織夢data目錄下的sessions文件夾有什


