成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

T-SQL查詢進階--流程控制語句

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

概述

和其他高級語言一樣,T-SQL中也有用于控制流程的語句。T-SQL中的流程控制語句進一步擴展了T-SQL的力量……使得大部分業(yè)務邏輯可以在數(shù)據(jù)庫層面進行。但很多人對T-SQL中的流程控制語句并沒有系統(tǒng)的了解,本篇文章會系統(tǒng)的對T-SQL語句中的流程控制語句進行系統(tǒng)講解。

基本概念

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

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

流程控制語句的使用范圍和GO關鍵字

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

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

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

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

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

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

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

#p#

T-SQL中的8個流程控制語句關鍵字

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

 

BEGIN...END

BREAK

GOTO

CONTINUE

IF...ELSE

WHILE

RETURN

WAITFOR

下面對上述關鍵字進行挨個講解

BEGIN…END關鍵字

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

WHILE/BREAK/CONTINUE關鍵字

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

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

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

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

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

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

IF..ELSE關鍵字

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

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

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

GOTO關鍵字

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

#p#

RETURN關鍵字

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

簡單的Return概念如下例子:

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

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

 

WAITFOR關鍵字

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

 

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

簡單的語法例子如下:

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

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

總結

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

原文鏈接:http://www.cnblogs.com/CareySon/archive/2011/08/23/2150434.html

【編輯推薦】

  1. CouchDB和SQLite聯(lián)合推出NoSQL查詢語言
  2. 在SQLite中通過Replace來實現(xiàn)插入和更新
  3. 微軟WP7本地數(shù)據(jù)庫之SQLite編程技巧
  4. 微軟WP7本機數(shù)據(jù)庫解決方案之SQLite
責任編輯:艾婧 來源: 宋沄劍的博客
相關推薦

2011-08-23 13:36:11

T-SQL查詢流程控制語句

2011-10-19 10:07:16

T-SQL查詢變量

2010-07-20 13:52:27

SQL Server

2011-07-18 14:38:44

子查詢外部查詢

2010-10-19 16:06:26

SQL Server索

2024-06-06 09:09:41

SQL循環(huán)控制命令

2010-05-11 12:53:58

Unix awk

2010-12-06 09:26:23

SQL Server

2024-11-01 16:05:26

2010-07-19 10:11:58

Perl流程控制語句

2009-09-04 10:42:56

C#流程控制語句

2011-03-31 09:30:27

SQL Server數(shù)管理SQL

2015-07-23 15:17:37

JavaScript循環(huán)語句

2024-11-05 12:59:42

while 循環(huán)迭代字節(jié)碼

2010-07-06 10:36:35

SQL Server

2011-10-09 16:40:50

T-SQL

2017-05-31 17:09:52

LinuxShell命令

2016-08-29 20:51:16

awkLinux開源

2023-08-15 08:26:34

SQL Server查找死鎖

2022-07-27 08:31:28

SQL開發(fā)控制
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区自拍 | 91在线观看网址 | 精品亚洲一区二区 | 亚洲伊人精品酒店 | 91污在线 | 亚洲免费精品 | 久久久久免费观看 | 在线三级电影 | 亚洲一区二区三区在线播放 | 国精品一区二区 | 亚洲交性 | 99久久精品国产一区二区三区 | 亚洲欧美在线观看 | 日本三级网址 | 亚洲高清在线视频 | 日韩免费在线视频 | 草久久久 | 日日欧美 | 国产精品我不卡 | 亚洲精品一 | 欧美1页| 欧美二区三区 | 在线观看av网站永久 | 中文字幕一区在线 | 日韩高清国产一区在线 | 夜夜骚 | 久久精品亚洲一区 | 午夜免费小视频 | 国产精品99久久久久 | 秋霞电影院午夜伦 | 黄网站在线播放 | 精品欧美激情精品一区 | 盗摄精品av一区二区三区 | 亚洲成人天堂 | www操操 | 黄网站在线播放 | 亚洲视频免费在线播放 | 91成人影院 | 亚洲一区 中文字幕 | 亚洲精品电影网在线观看 | 日韩在线观看网站 |