日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
T-SQL查詢進階之流程控制語句詳解

T-SQL查詢中用于流程控制的語句是本文我們主要要介紹的內(nèi)容,T-SQL中的流程控制語句進一步擴展了T-SQL的力量……使得大部分業(yè)務(wù)邏輯可以在數(shù)據(jù)庫層面進行。但很多人對T-SQL中的流程控制語句并沒有系統(tǒng)的了解,本篇文章會系統(tǒng)的對T-SQL語句中的流程控制語句進行系統(tǒng)講解。

為西豐等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及西豐網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計、成都網(wǎng)站制作、西豐網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

基本概念

在沒有流程控制語句的情況下,T-SQL語句是按照從上到下的順序逐個執(zhí)行:

使用流程控制語句可以讓開發(fā)人員可以基于某些邏輯進行選擇性的跳轉(zhuǎn),實現(xiàn)了類似高級語言的跳轉(zhuǎn)結(jié)構(gòu):

流程控制語句的使用范圍和GO關(guān)鍵字

流程控制語句只能在單個批處理段(Batch),用戶自定義函數(shù)和存儲過程中使用。不能跨多個批處理段或者用戶自定義函數(shù)和存儲過程。

因為這里重點講到T-SQL查詢語句,所以這里只講批處理段(Batch).

一個批處理段是由一個或者多個語句組成的一個批處理,之所以叫批處理是因為所有語句一次性被提交到一個SQL實例。在這個批處理范圍內(nèi),局部變量是互相可見的。

而想讓多個語句分多次提交到SQL實例,則需要使用GO關(guān)鍵字。GO關(guān)鍵字本身并不是一個SQL語句,GO關(guān)鍵字可以看作是一個批處理結(jié)束的標(biāo)識符,當(dāng)遇到GO關(guān)鍵字時,當(dāng)前GO之前的語句會作為一個批處理直接傳到SQL實例執(zhí)行。所以不在同一個批處理內(nèi)局部變量不可見,也不可對跨批處理的語句使用流程控制語句.

在同一個批處理中局部變量互相可見:

在不同批處理中局部變量不可見:

在不同批處理中,流程控制語句不能跨批處理:

T-SQL中的8個流程控制語句關(guān)鍵字

在T-SQL中,與流程控制語句相關(guān)的關(guān)鍵字有8個:

BEGIN...END

BREAK

GOTO

CONTINUE

IF...ELSE

WHILE

RETURN

WAITFOR

下面對上述關(guān)鍵字進行逐個講解:

BEGIN…END關(guān)鍵字

BEGIN…END關(guān)鍵字也是流程控制語句需要用到的最基本關(guān)鍵字,用于將多個語句劃分成邏輯上的一部分。其實可以直接理解成類C語言中的花括號(“{}"“)

WHILE/BREAK/CONTINUE關(guān)鍵字

在T-SQL的流程控制語句中,循環(huán)語句只有WHILE循環(huán),并沒有傳統(tǒng)高級語言的FOR和SWITCH循環(huán)。WHILE除了被用于流程控制語句的循環(huán)之外,還經(jīng)常被用于游標(biāo)之中。

WHILE關(guān)鍵字和高級語言中的WHILE關(guān)鍵字幾乎完全一樣。WHILE循環(huán)中可以利用BREAK和CONTINUE關(guān)鍵字對循環(huán)進行控制。

CONTINUE關(guān)鍵字:用于結(jié)束本次循環(huán),直接開始下一次循環(huán)。

BREAK關(guān)鍵字:用于直接跳出WHILE循環(huán)語句。

這里值得注意的是,當(dāng)WHILE循環(huán)嵌套時,CONTINUE關(guān)鍵字和BREAK關(guān)鍵字只會作用于它們所處的WHILE循環(huán)之內(nèi),不會對外部WHILE循環(huán)產(chǎn)生作用。

一個簡單的例子如下:從1循環(huán)到10,當(dāng)循環(huán)到7時,結(jié)束本次循環(huán)并繼續(xù),當(dāng)循環(huán)到8時,跳出循環(huán)

IF..ELSE關(guān)鍵字

IF..ELSE關(guān)鍵字實現(xiàn)了非此既彼的邏輯。和高級語言中的IF..ELSE具有完全一樣的使用方法,這里就不再講述了,例子參看上圖。

還有要注意的是IF經(jīng)常會和EXISTS關(guān)鍵字相結(jié)合來查看數(shù)據(jù)表中指定的數(shù)據(jù)是否存在,比如:

我想查詢員工中沒有上級的人,如果有這個人,則輸出“XXX is our boss”,如果沒有,則輸出"There is no infomation about our boss”

GOTO關(guān)鍵字

GOTO關(guān)鍵字因為能打亂程序的整個流程而在高級語言中臭名卓著。GOTO關(guān)鍵字的使用非常簡單,定義一個跳轉(zhuǎn)標(biāo)簽,只要GOTO 標(biāo)簽名就可以。如果說一定要使用GOTO關(guān)鍵字的話,最佳實踐是只使用在錯誤處理上,比如:

RETURN關(guān)鍵字

Return是最簡單有效直接無條件告訴服務(wù)器跳出某個批處理段(Batch),用戶自定義函數(shù)和存儲過程的方式。在同一個批處理中Return關(guān)鍵字直接截止當(dāng)前Return所在的批處理(Batch),批處理有關(guān)概念請參考前面GO關(guān)鍵字那一節(jié).

簡單的Return概念如下例子:

在存儲過程中,Return語句后面可以返回數(shù)字用于返回執(zhí)行狀態(tài)或者錯誤代碼。

很多人會把Return語句和RAISERROR函數(shù)搞混,區(qū)別在于RAISERROR函數(shù)會引發(fā)錯誤,并且程序依然會往下執(zhí)行:

WAITFOR關(guān)鍵字

WAITFOR關(guān)鍵字允許指定語句在特定時間或是推遲特定時間執(zhí)行。

推遲等待和在特定時間執(zhí)行的語法分別是WAITFOR DELAY ‘需要等待的執(zhí)行時間',WAITFOR TIME ‘需要執(zhí)行程序的精確時間’

簡單的語法例子如下:

WAITFOR的功能可以實現(xiàn)更為復(fù)雜的業(yè)務(wù)邏輯,比如:

我想開始一項促銷活動,在當(dāng)前時間10小時后開始,為8折,20小時后結(jié)束,變?yōu)?折:

總結(jié)

本篇文章從T-SQL查詢的角度講解了流程控制語句的8個關(guān)鍵字。利用好這些關(guān)鍵字是掌握復(fù)雜T-SQL查詢的必要條件。

以上就是就是T-SQL數(shù)據(jù)庫查詢中用于流程控制的語句以及它的關(guān)鍵詞的用法的全部內(nèi)容,希望本次的介紹能夠?qū)δ兴斋@!

【編輯推薦】

  1. SQL Server 2008 MDX應(yīng)用之組裝有序集合
  2. SQL Server 2008中的代碼安全之主密鑰詳解
  3. SQL Server 2008 MDX應(yīng)用之檢索集合中的元組
  4. SQL Server 2005/2008中的CTE應(yīng)用之遞歸查詢
  5. 淺析SQL Server數(shù)據(jù)庫SSIS導(dǎo)入IIS日志的簡單步驟

本文標(biāo)題:T-SQL查詢進階之流程控制語句詳解
轉(zhuǎn)載注明:http://m.5511xx.com/article/ccdigeg.html