




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
T-SQL批處理和流程控制課程安排批處理T-SQL基礎(chǔ)begin...endif...else...while循環(huán)case分支waitfor語句批處理
所謂批處理是指從客戶機(jī)傳遞到服務(wù)器上的一組完整的數(shù)據(jù)和SQL指令。在一個(gè)批處理中,可以只包含一條SQL指令,也可以包含多條指令。批處理的所有語句被當(dāng)作一個(gè)整體,而被成批地分析、編譯和執(zhí)行,若這一批處理中存在一個(gè)語法錯(cuò)誤,則所有的語句都無法通過編譯。所有的批處理指令以GO作為結(jié)束的標(biāo)志,當(dāng)編譯器讀到GO時(shí),它就會(huì)把GO前面的所有指令當(dāng)作一個(gè)批處理,并包裝成一個(gè)數(shù)據(jù)包發(fā)送給服務(wù)器。T-SQL基礎(chǔ)一、注釋語句
--:一行注釋(注釋的內(nèi)容不超過一行)
/**/:一段注釋(當(dāng)注釋的內(nèi)容超過一行)二、輸出語句:PRINT語句。
PRINT語句把用戶定義的消息返回客戶端,其基本語句格式如下所示:
PRINT<字符串表達(dá)式>T-SQL基礎(chǔ):變量
變量指的是在程序運(yùn)行過程中值可以發(fā)生變化的量。
SQL分為兩種類型的變量:全局變量和局部變量。其中全局變量是系統(tǒng)已經(jīng)定義好的變量,主要反映SQL數(shù)據(jù)庫的操作狀態(tài)。全局變量名稱以@@開頭;局部變量由用戶定義,主要用于保存運(yùn)算結(jié)果,局部變量的名稱必須以@開頭。標(biāo)識(shí)符的命名常規(guī)標(biāo)識(shí)符應(yīng)遵守以下的命名規(guī)則:標(biāo)識(shí)符長(zhǎng)度可以為1-128個(gè)字符。對(duì)于本地臨時(shí)表,標(biāo)識(shí)符最多可以有116個(gè)字符。標(biāo)識(shí)符的首字符必須為Unicode3.2標(biāo)準(zhǔn)所定義的字母或_、@、#符號(hào)。標(biāo)識(shí)符第一個(gè)字符后面的字符可以為Unicode3.2標(biāo)準(zhǔn)所定義的字符、數(shù)字或@、#、$、_符號(hào)。標(biāo)識(shí)符內(nèi)不能嵌入空格或其他特殊字符。標(biāo)識(shí)符不能與SQLServer中的保留關(guān)鍵字同名。T-SQL基礎(chǔ):變量和運(yùn)算符局部變量
聲明變量:T-SQL中使用DECLARE語句聲明變量,并在聲明后將變量的值初始化為NULL。在一個(gè)DECLARE語句中可以同時(shí)聲明多個(gè)局部變量,它們相互之間用逗號(hào)分隔。DECLARE語句的基本語句格式如下:
DECLARE<@變量名1><數(shù)據(jù)類型>[,<@變量名2><數(shù)據(jù)類型>……]T-SQL基礎(chǔ):變量和運(yùn)算符變量賦值
用SET、SELECT給局部變量賦值
語法格式:SET@局部變量=表達(dá)式
SELECT{@局部變量=表達(dá)式}[,…n]SET只能給一個(gè)變量賦值,而SELECT可以給多個(gè)變量賦值。兩種格式可以通用,建議首選使用SET,而不推薦使用SELECT語句。
表達(dá)式中可以包含SELECT語句子查詢,但只能是集合函數(shù)
返回的單值。且必須用圓括號(hào)括起來。
SELECT也可以直接使用查詢的單值結(jié)果給局部變量賦值。如:SELECT@局部變量=表達(dá)式或字段名FROM表名WHERE條件T-SQL基礎(chǔ):變量和運(yùn)算符局部變量的顯示:
SELECT<@變量名表>
PRINT<@變量名>局部變量的作用域:
在一個(gè)批處理、一個(gè)存儲(chǔ)過程或一個(gè)觸發(fā)器內(nèi),其生命周期從定義開始到它遇到的第一個(gè)GO語句或者到存儲(chǔ)過程、觸發(fā)器的結(jié)尾結(jié)束,即局部變量只在當(dāng)前的批處理、存儲(chǔ)過程、觸發(fā)器中有效。
如果在批處理、存儲(chǔ)過程、觸發(fā)器中使用其他批處理、存儲(chǔ)過程、觸發(fā)器定義的變量,則系統(tǒng)出現(xiàn)錯(cuò)誤并提示“必須聲明變量”。T-SQL基礎(chǔ):全局變量全局變量全局變量是由系統(tǒng)提供的有確定值的變量,用戶不能自己定義全局變量,也不能用SET語句來修改全局變量的值。系統(tǒng)全局變量都是以@@開頭的,全局變量實(shí)際上是一些特殊的不需要參數(shù)、也不需要加括號(hào)調(diào)用的函數(shù),可直接返回特定的值。例如:@@error:其值為最后一次執(zhí)行錯(cuò)誤的SQL語句產(chǎn)生的錯(cuò)誤代碼@@max_connections:其值為SQLServer允許多用戶同時(shí)連接的最大數(shù)@@connections:SQLServer最近一次啟動(dòng)后已連接或嘗試連接的次數(shù)@@version:本地SQLServer服務(wù)器的版本信息T-SQL流程控制語句
T-SQL語言與其它高級(jí)語言一樣,提供了可以控制程序執(zhí)行流程的語句。使用這些流程控制語句可以更好地組織和控制程序的流程。
1、順序控制語句BEGIN…END語句塊
BEGIN語句1語句2…END不論多少個(gè)語句,放在BEGIN…END中間就構(gòu)成一個(gè)獨(dú)立的語句塊,被系統(tǒng)當(dāng)作一個(gè)整體單元來處理。條件的某個(gè)分支或循環(huán)體語句中,如果要執(zhí)行兩個(gè)以上的復(fù)合語句,則必須將它們放在BEGIN…END中間。T-SQL流程控制語句2、條件判斷語法格式:if
邏輯表達(dá)式{語句|語句塊}[else{語句|語句塊}]作用:按條件控制程序的執(zhí)行。當(dāng)條件滿足時(shí),則在執(zhí)行條件之后的T-SQL語句。否則,就執(zhí)行else后的T-SQL語句(若ELSE部分存在)。T-SQL流程控制語句3、WHILE循環(huán)語句
WHILE條件表達(dá)式BEGIN循環(huán)體語句系列…[BREAK]……[CONTINUE]……END執(zhí)行過程:先計(jì)算判斷條件表達(dá)式的值若條件為真則執(zhí)行BEGIN…END之間的循環(huán)體語句系列,執(zhí)行到END時(shí)返回到WHILE再次判斷條件表達(dá)式的值。若條件為假,則直接跳過BEGIN…END不執(zhí)行循環(huán)。若在執(zhí)行循環(huán)體時(shí)遇到BREAK語句,則無條件跳出BEGIN…END。若在執(zhí)行循環(huán)體時(shí)遇到CONTINUE語句,則結(jié)束本輪循環(huán),不再執(zhí)行之后的循環(huán)體語句,返回到WHILE再次判斷條件表達(dá)式的值。T-SQL流程控制語句4、CASE結(jié)構(gòu)CASE結(jié)構(gòu)用于多條件分支選擇,可以完成計(jì)算多個(gè)條件并為每個(gè)條件返回單個(gè)值。支持兩種格式:(1)簡(jiǎn)單CASE…END表達(dá)式
CASE測(cè)試表達(dá)式WHEN常量值1THEN結(jié)果表達(dá)式1[{WHEN常量值2THEN結(jié)果表達(dá)式2}[…n]][ELSE結(jié)果表達(dá)式n]END功能:根據(jù)測(cè)試表達(dá)式的值得到一個(gè)對(duì)應(yīng)值。執(zhí)行過程:先計(jì)算測(cè)試表達(dá)式的值,將測(cè)試表達(dá)式的值按順序依次與WHEN指定的各個(gè)常量值進(jìn)行比較;如果找到了一個(gè)相等常量值,則整個(gè)CASE表達(dá)式取相應(yīng)THEN指定的結(jié)果表達(dá)式的值,之后不再比較,跳出CASE…END;如果找不到相等的常量值,則取ELSE指定的結(jié)果表達(dá)式n;如果找不到相等的常量值也沒有使用ELSE,則返回NULL。T-SQL流程控制語句(2)搜索CASE…END表達(dá)式CASEWHEN條件表達(dá)式1THEN結(jié)果表達(dá)式1[{WHEN條件表達(dá)式2THEN結(jié)果表達(dá)式2}[…n]][ELSE結(jié)果表達(dá)式n]END功能:根據(jù)某個(gè)條件得到一個(gè)對(duì)應(yīng)值。注意:搜索CASE表達(dá)式與簡(jiǎn)單CASE表達(dá)式的語法區(qū)別是CASE后沒有測(cè)試表達(dá)式,WHEN指定的不是常量值而是條件表達(dá)式。執(zhí)行過程:按順序依次判斷WHEN指定條件表達(dá)式的值,遇到第一個(gè)為真的條件表達(dá)式,則整個(gè)CASE表達(dá)式取對(duì)應(yīng)THEN指定的結(jié)果表達(dá)式的值,之后不再比較,結(jié)束并跳出CASE…END。如果找不到為真的條件表達(dá)式,則取ELSE指定的結(jié)果表達(dá)式n。如果找不到為真的條件表達(dá)式也沒有使用ELSE,則返回NULL。T-SQL流程控制語句5waitfor等待語句
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東酒店管理職業(yè)技術(shù)學(xué)院《Java語言程序設(shè)計(jì)B》2023-2024學(xué)年第二學(xué)期期末試卷
- 江蘇海事職業(yè)技術(shù)學(xué)院《植物營養(yǎng)分子生物學(xué)基礎(chǔ)》2023-2024學(xué)年第二學(xué)期期末試卷
- 公司門衛(wèi)管理制度及崗位職責(zé)
- 【2025年飲食產(chǎn)業(yè)布局加速:澳門零售與餐飲市場(chǎng)呈現(xiàn)分化趨勢(shì)】
- 監(jiān)控機(jī)房施工方案
- 直線段支架施工方案
- 保溫冷棚施工方案
- 一卡通方案資料
- 5年級(jí)下冊(cè)數(shù)學(xué)所有公式
- 5年級(jí)第6單元語文園地筆記上冊(cè)
- 2025年滁州城市職業(yè)學(xué)院?jiǎn)握芯C合素質(zhì)考試題庫必考題
- 第12課 遼宋夏金元時(shí)期經(jīng)濟(jì)的繁榮【公開課一等獎(jiǎng)創(chuàng)新教學(xué)設(shè)計(jì)】-【教學(xué)評(píng)一體化】大單元整體教學(xué)
- 《復(fù)雜系統(tǒng)理論》課件
- 2025福建省電力電網(wǎng)有限公司高校畢業(yè)生(第一批)招聘748人筆試參考題庫附帶答案詳解
- 初中英語語法時(shí)態(tài)總復(fù)習(xí)課件
- 人教版(2025新版)七年級(jí)下冊(cè)數(shù)學(xué)第七章 相交線與平行線 單元測(cè)試卷(含答案)
- 汽輪機(jī)輔機(jī)培訓(xùn)
- 國之重器:如何突破關(guān)鍵技術(shù)-筆記
- 早產(chǎn)兒和低出生體重兒袋鼠式護(hù)理臨床實(shí)踐指南(2024)解讀1
- 三廢環(huán)保管理培訓(xùn)
- 腐蝕與防護(hù)-第五章 析氫腐蝕與耗氧腐蝕
評(píng)論
0/150
提交評(píng)論