版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
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è)語法錯誤,則所有的語句都無法通過編譯。所有的批處理指令以GO作為結(jié)束的標(biāo)志,當(dāng)編譯器讀到GO時(shí),它就會把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)識符的命名常規(guī)標(biāo)識符應(yīng)遵守以下的命名規(guī)則:標(biāo)識符長度可以為1-128個(gè)字符。對于本地臨時(shí)表,標(biāo)識符最多可以有116個(gè)字符。標(biāo)識符的首字符必須為Unicode3.2標(biāo)準(zhǔn)所定義的字母或_、@、#符號。標(biāo)識符第一個(gè)字符后面的字符可以為Unicode3.2標(biāo)準(zhǔn)所定義的字符、數(shù)字或@、#、$、_符號。標(biāo)識符內(nèi)不能嵌入空格或其他特殊字符。標(biāo)識符不能與SQLServer中的保留關(guān)鍵字同名。T-SQL基礎(chǔ):變量和運(yùn)算符局部變量
聲明變量:T-SQL中使用DECLARE語句聲明變量,并在聲明后將變量的值初始化為NULL。在一個(gè)DECLARE語句中可以同時(shí)聲明多個(gè)局部變量,它們相互之間用逗號分隔。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ù)
返回的單值。且必須用圓括號括起來。
SELECT也可以直接使用查詢的單值結(jié)果給局部變量賦值。如:SELECT@局部變量=表達(dá)式或字段名FROM表名WHERE條件T-SQL基礎(chǔ):變量和運(yùn)算符局部變量的顯示:
SELECT<@變量名表>
PRINT<@變量名>局部變量的作用域:
在一個(gè)批處理、一個(gè)存儲過程或一個(gè)觸發(fā)器內(nèi),其生命周期從定義開始到它遇到的第一個(gè)GO語句或者到存儲過程、觸發(fā)器的結(jié)尾結(jié)束,即局部變量只在當(dāng)前的批處理、存儲過程、觸發(fā)器中有效。
如果在批處理、存儲過程、觸發(fā)器中使用其他批處理、存儲過程、觸發(fā)器定義的變量,則系統(tǒng)出現(xiàn)錯誤并提示“必須聲明變量”。T-SQL基礎(chǔ):全局變量全局變量全局變量是由系統(tǒng)提供的有確定值的變量,用戶不能自己定義全局變量,也不能用SET語句來修改全局變量的值。系統(tǒng)全局變量都是以@@開頭的,全局變量實(shí)際上是一些特殊的不需要參數(shù)、也不需要加括號調(diào)用的函數(shù),可直接返回特定的值。例如:@@error:其值為最后一次執(zhí)行錯誤的SQL語句產(chǎn)生的錯誤代碼@@max_connections:其值為SQLServer允許多用戶同時(shí)連接的最大數(shù)@@connections:SQLServer最近一次啟動后已連接或嘗試連接的次數(shù)@@version:本地SQLServer服務(wù)器的版本信息T-SQL流程控制語句
T-SQL語言與其它高級語言一樣,提供了可以控制程序執(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)簡單CASE…END表達(dá)式
CASE測試表達(dá)式WHEN常量值1THEN結(jié)果表達(dá)式1[{WHEN常量值2THEN結(jié)果表達(dá)式2}[…n]][ELSE結(jié)果表達(dá)式n]END功能:根據(jù)測試表達(dá)式的值得到一個(gè)對應(yīng)值。執(zhí)行過程:先計(jì)算測試表達(dá)式的值,將測試表達(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è)對應(yīng)值。注意:搜索CASE表達(dá)式與簡單CASE表達(dá)式的語法區(qū)別是CASE后沒有測試表達(dá)式,WHEN指定的不是常量值而是條件表達(dá)式。執(zhí)行過程:按順序依次判斷WHEN指定條件表達(dá)式的值,遇到第一個(gè)為真的條件表達(dá)式,則整個(gè)CASE表達(dá)式取對應(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等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 冀少版八年級生物上冊第三、四、五章整合練課件
- 企業(yè)商務(wù)接待規(guī)范指南
- 人力資源合規(guī)風(fēng)險(xiǎn)防范成本分析
- 北京市禮品合同
- 智能化印刷生產(chǎn)施工合同
- 電力系統(tǒng)升級施工合同范本
- 畜牧業(yè)用地租賃合同
- 社區(qū)義工活動策劃與實(shí)施
- 交響樂團(tuán)指揮聘任合同
- 教育信息化項(xiàng)目投標(biāo)保證金辦法
- 2024口腔執(zhí)業(yè)醫(yī)師聘用合同
- 2024-2025學(xué)年人教版生物七年級上冊期中備考重點(diǎn)知識
- 低空經(jīng)濟(jì)招商引資策略與措施
- 第10課《我們不亂扔》(課件)-部編版道德與法治二年級上冊
- 陽光心理-健康人生小學(xué)生心理健康主題班會課件
- 中圖版七年級下冊信息技術(shù) 4.1策劃數(shù)字故事 教學(xué)設(shè)計(jì)
- 和燈做朋友(教學(xué)設(shè)計(jì))-2023-2024學(xué)年五年級上冊綜合實(shí)踐活動蒙滬版
- 2024年江蘇蘇州高新區(qū)(虎丘區(qū))城鄉(xiāng)發(fā)展局公益性崗位招聘3人歷年高頻考題難、易錯點(diǎn)模擬試題(共500題)附帶答案詳解
- 樂理知識考試題庫130題(含答案)
- 人教版(2024)七年級地理上冊2.2《地形圖的判讀》精美課件
- 黃河商品交易市場介紹稿
評論
0/150
提交評論