使用公用表表達式的遞歸查詢

  微軟從SQL2005起引入了CTE(Common Table Expression)以強化T-SQL

  公用表表達式?(CTE)?具有一個重要的長處,那就是可以引用其自身。從而創建遞歸?CTE。遞歸?CTE?是一個反復運行初始?CTE?以返回數據子集直到獲取完整結果集的公用表表達式。

  當某個查詢引用遞歸?CTE?時。它即被稱為遞歸查詢。遞歸查詢通經常使用于返回分層數據,比如:顯示某個組織圖中的雇員或物料清單方案(當中父級產品有一個或多個組件,而那些組件可能還有子組件,或者是其它父級產品的組件)中的數據。

  遞歸?CTE?能夠極大地簡化在?SELECTINSERTUPDATEDELETE??CREATE VIEW?語句中執行遞歸查詢所需的代碼。在?SQL Server?的早期版本號中。遞歸查詢通常須要使用暫時表、游標和邏輯來控制遞歸步驟流。有關公用表表達式的具體信息。請參閱使用公用表表達式

?

偽代碼和語義

————————————————————————————

遞歸?CTE?結構必須至少包括一個定位點成員和一個遞歸成員。下面偽代碼顯示了包括一個定位點成員和一個遞歸成員的簡單遞歸?CTE?的組件。

WITH?cte_name?(?column_name [,...n]?)

AS

(

CTE_query_definition?–- Anchor member is defined.

UNION?ALL

CTE_query_definition?–- Recursive member is defined referencing cte_name.

)

-- Statement using the CTE

SELECT?*?FROM?cte_name

遞歸運行的語義例如以下:

  1. 將?CTE?表達式拆分為定位點成員和遞歸成員。
  2. 執行定位點成員。創建第一個調用或基準結果集?(T0)。
  3. 執行遞歸成員,將?Ti?作為輸入,將?Ti+1?作為輸出。

  4. 反復步驟?3,直到返回空集。
  5. 返回結果集。這是對?T0?到?Tn?執行?UNION ALL?的結果。?

?

演示樣例

————————————————————————————

原表:

?

?

 如今有一個需求,要查詢出某個省以下的全部市和區(查詢結果包括省)。假設僅僅使用SQL語句來實現,須要使用到游標、暫時表等技術。

但在SQL Server2005中還能夠使用CTE來實現。

?

WITH?district

AS

(

????--獲得第一個結果集,并更新終于結果集

????SELECT?*?FROM?t_tree?WHERE?id?=?0

????UNION?ALL

????--以下的select語句首先會依據從上一個查詢結果集中獲得的id值來查詢parent_id

????--字段的值,然后district就會變當前的查詢結果集。并繼續運行以下的select?語句

????--假設結果集不為null。則與終于的查詢結果合并,同一時候用合并的結果更新終于的查

????--詢結果;否則停止運行。

最后district的結果集就是終于結果集。

????SELECT a.* FROM?t_tree aINNER JOIN district?bONa.parent_id = b.id

)

SELECT?*?FROM?district

?

查詢結果:


?

有關使用公用表表達式的具體信息,請參閱使用公用表表達式的遞歸查詢。

轉載于:https://www.cnblogs.com/bhlsheji/p/5112810.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/458435.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/458435.shtml
英文地址,請注明出處:http://en.pswp.cn/news/458435.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C#委托實現C++ Dll中的回調函數

from:https://blog.csdn.net/ferrycooper/article/details/63261771很多的Dll都是C和C寫的,那么如果C#想要調用Dll中的函數怎么辦,尤其是Dll函數其中一個參數是函數指針的,即里面有回掉函數的用C#怎么實現? C中的回掉函數在C#中有…

安裝Birt方法

安裝BIRT 方法: 博客地址:http://www.mamicode.com/info-detail-850588.html 注意:在 Install new Software 中輸入地址:http://download.eclipse.org/birt/update-site/4.2-interim 看好了 出來的四項要全部選中 ,然后…

iOS NSString和NSDate轉換

后臺返回的時間字符串不是標準的時間而是計算機時間的時候,我們需要將它們轉換為標準時間,再進行轉換。 //字符串轉為時間,時間格式自己定 NSString * time "1501776000"; //時間字符串 NSInteger num [time integerValue]; …

15個最好的HTML5前端響應式框架(2014)

文中的多個框架基于SASS創建,SCSS是一種比LESS更簡潔的樣式表編程語言,它能夠編繹成CSS,可復用CSS代碼,聲明變量,甚至是函數,類Ruby/Python的語法。參見: LESS vs SASS?選擇哪種CSS樣…

DLL導出類和導出函數

from:https://blog.csdn.net/goodluckmt/article/details/526912971、動態庫DLL中的類或者函數有時候要被其他的庫調用,因此需要被其他庫調用的類或者函數需要進行導出。 2、首先編寫需要導出的DLL,新建一個工程設置應用程序類型為DLL3、類的代碼如下 頭…

Nginx做web服務器linux內核參數優化

Nginx做web服務器linux內核參數優化Nginx提供web服務時Linux內核參數調整是必不可少的,其中在優化方面就需要我們格外的注意。在下面就是對Linux內核參數優化的詳細介紹,希望大家有所收獲。關于Linux內核參數的優化:net.ipv4.tcp_max_tw_buck…

iOS系統發布時間

發布日期 版本編號 更改2017年9月12日 iOS11 GM seed2017年6月19日 iOS10.3.32016年11月9日 iOS10.2 Beta2 發布iOS10.2測試版版2016年11月1日 iOS10.2 Beta1 發布iOS10.2測試版版2016年10月25日 iOS10.1 發布iOS10.1正式版2016年9月22日 iOS10.1 Beta 發布iOS10.1測試版2016年…

Tomacat服務器的安裝和配置

一, Tomcat服務器的下載地址(Apache Tomcat的官網): http://tomcat.apache.org/download-70.cgi 這里為了穩定性安裝的版本為7.0. 截止目前版本已經發行到了9.0. 二, 解壓下載的壓縮包之后直接進入傻瓜式的安裝。   下載文件的全名: apach…

函數指針與回調函數詳解

函數指針與回調函數詳解 1.什么是函數指針? 函數(的)指針就是指針。這個指針存放一個函數的地址,而函數的名稱就該函數的入口,即地址。這類似于數組名就是數組的首地址。我們可以通過反匯編直觀的查看到函數名和函數地…

【轉載】Direct3D基礎知識

原文:Direct3D基礎知識 重新從頭開始學習DX,以前太急于求成了,很多基礎知識都沒掌握就開始寫程序了,結果出了問題很難解決.1. D3D體系結構D3D與GDI處與同一層次,區別在于,D3D可以使用HAL(Hardware Abstraction Layer)通過DDI來訪問圖形硬件,充分發揮硬件性能.…

翻譯:程序員數據結構基礎:選擇正確的數據結構

本文轉載自GameDev.net,僅供學習交流。因為剛剛開始學習翻譯,難免有些疏漏,如果有哪些地方翻譯的不正確,請不吝告知,萬分感謝。 原文鏈接:http://www.gamedev.net/page/resources/_/technical/general-prog…

關于Xcode隱藏打印的logs的方法

https://www.cnblogs.com/jukaiit/p/5881062.html 第一步: 第二步: 第三步: 添加參數: Name :OS_ACTIVITY_MODE Value : disable

指針函數與函數指針的區別

首先它們之間的定義:1、指針函數是指帶指針的函數,即本質是一個函數,函數返回類型是某一類型的指針。 類型標識符 *函數名(參數表)int *f(x,y);首先它是一個函數,只不過這個函數的返回值是一個地址值。函數返回值必須用…

數組字典

#import <Foundation/Foundation.h>int main(int argc, const char * argv[]) {autoreleasepool { //把字典放到數組中NSDictionary *dic1{"name":"小明","class":"IOS8","age":"22"};NSDictionary *dic2{&…

C++走向遠洋——63(項目二2、兩個成員的類模板)

*/ * Copyright (c) 2016&#xff0c;煙臺大學計算機與控制工程學院 * All rights reserved. * 文件名&#xff1a;text.cpp * 作者&#xff1a;常軒 * 微信公眾號&#xff1a;Worldhello * 完成日期&#xff1a;2016年6月4日 * 版本號&#xff1a;V1.0 * 問題描述&…

iOS 抓包工具 charles工具

在Charles官網下載最新的 安裝包 在電腦上安裝完成之后&#xff0c;以 注冊碼 Registered Name: https://zhile.io License Key: 48891cf209c6d32bf4 進行注冊即可完成 在手機上面設置代理&#xff1a;輸入電腦的網絡IP以及端口號 以下為查找的步驟&#xff1a; 在手機上手…

指針數組與數組指針詳解

指針數組與數組指針詳解 1.什么是指針數組和數組指針&#xff1f; 指針數組&#xff1a;指針數組可以說成是”指針的數組”&#xff0c;首先這個變量是一個數組&#xff0c;其次&#xff0c;”指針”修飾這個數組&#xff0c;意思是說這個數組的所有元素都是指針類型&#xff0…

寫一個Android輸入法01——最簡步驟

本文演示用Android Studio寫一個最簡單的輸入法。界面和交互都很簡陋&#xff0c;只為剔肉留骨&#xff0c;彰顯寫一個Android輸入法的要點。 1、打開Android Studio創建項目&#xff0c;該項目和普通APP的不同之處在于它不需要添加任何Activity&#xff1a;我給該輸入法命名為…

句柄與指針的區別

句柄實際上是一種指向某種資源的指針&#xff0c;但與指針又有所不同&#xff1a;指針對應著一個數據在內存中的地址&#xff0c;得到了指針就可以自由地修改該數據。 Windows并不希望一般程序修改其內部數據結構&#xff0c;因為這樣太不安全。所以Windows給每個使用GlobalAll…

iOS 11 適配

http://blog.csdn.net/st646889325/article/details/79066361 這一個不錯的文章