




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
T-SQL批處理和流程控制課程安排批處理T-SQL基礎begin...endif...else...while循環case分支waitfor語句批處理
所謂批處理是指從客戶機傳遞到服務器上的一組完整的數據和SQL指令。在一個批處理中,可以只包含一條SQL指令,也可以包含多條指令。批處理的所有語句被當作一個整體,而被成批地分析、編譯和執行,若這一批處理中存在一個語法錯誤,則所有的語句都無法通過編譯。所有的批處理指令以GO作為結束的標志,當編譯器讀到GO時,它就會把GO前面的所有指令當作一個批處理,并包裝成一個數據包發送給服務器。T-SQL基礎一、注釋語句
--:一行注釋(注釋的內容不超過一行)
/**/:一段注釋(當注釋的內容超過一行)二、輸出語句:PRINT語句。
PRINT語句把用戶定義的消息返回客戶端,其基本語句格式如下所示:
PRINT<字符串表達式>T-SQL基礎:變量
變量指的是在程序運行過程中值可以發生變化的量。
SQL分為兩種類型的變量:全局變量和局部變量。其中全局變量是系統已經定義好的變量,主要反映SQL數據庫的操作狀態。全局變量名稱以@@開頭;局部變量由用戶定義,主要用于保存運算結果,局部變量的名稱必須以@開頭。標識符的命名常規標識符應遵守以下的命名規則:標識符長度可以為1-128個字符。對于本地臨時表,標識符最多可以有116個字符。標識符的首字符必須為Unicode3.2標準所定義的字母或_、@、#符號。標識符第一個字符后面的字符可以為Unicode3.2標準所定義的字符、數字或@、#、$、_符號。標識符內不能嵌入空格或其他特殊字符。標識符不能與SQLServer中的保留關鍵字同名。T-SQL基礎:變量和運算符局部變量
聲明變量:T-SQL中使用DECLARE語句聲明變量,并在聲明后將變量的值初始化為NULL。在一個DECLARE語句中可以同時聲明多個局部變量,它們相互之間用逗號分隔。DECLARE語句的基本語句格式如下:
DECLARE<@變量名1><數據類型>[,<@變量名2><數據類型>……]T-SQL基礎:變量和運算符變量賦值
用SET、SELECT給局部變量賦值
語法格式:SET@局部變量=表達式
SELECT{@局部變量=表達式}[,…n]SET只能給一個變量賦值,而SELECT可以給多個變量賦值。兩種格式可以通用,建議首選使用SET,而不推薦使用SELECT語句。
表達式中可以包含SELECT語句子查詢,但只能是集合函數
返回的單值。且必須用圓括號括起來。
SELECT也可以直接使用查詢的單值結果給局部變量賦值。如:SELECT@局部變量=表達式或字段名FROM表名WHERE條件T-SQL基礎:變量和運算符局部變量的顯示:
SELECT<@變量名表>
PRINT<@變量名>局部變量的作用域:
在一個批處理、一個存儲過程或一個觸發器內,其生命周期從定義開始到它遇到的第一個GO語句或者到存儲過程、觸發器的結尾結束,即局部變量只在當前的批處理、存儲過程、觸發器中有效。
如果在批處理、存儲過程、觸發器中使用其他批處理、存儲過程、觸發器定義的變量,則系統出現錯誤并提示“必須聲明變量”。T-SQL基礎:全局變量全局變量全局變量是由系統提供的有確定值的變量,用戶不能自己定義全局變量,也不能用SET語句來修改全局變量的值。系統全局變量都是以@@開頭的,全局變量實際上是一些特殊的不需要參數、也不需要加括號調用的函數,可直接返回特定的值。例如:@@error:其值為最后一次執行錯誤的SQL語句產生的錯誤代碼@@max_connections:其值為SQLServer允許多用戶同時連接的最大數@@connections:SQLServer最近一次啟動后已連接或嘗試連接的次數@@version:本地SQLServer服務器的版本信息T-SQL流程控制語句
T-SQL語言與其它高級語言一樣,提供了可以控制程序執行流程的語句。使用這些流程控制語句可以更好地組織和控制程序的流程。
1、順序控制語句BEGIN…END語句塊
BEGIN語句1語句2…END不論多少個語句,放在BEGIN…END中間就構成一個獨立的語句塊,被系統當作一個整體單元來處理。條件的某個分支或循環體語句中,如果要執行兩個以上的復合語句,則必須將它們放在BEGIN…END中間。T-SQL流程控制語句2、條件判斷語法格式:if
邏輯表達式{語句|語句塊}[else{語句|語句塊}]作用:按條件控制程序的執行。當條件滿足時,則在執行條件之后的T-SQL語句。否則,就執行else后的T-SQL語句(若ELSE部分存在)。T-SQL流程控制語句3、WHILE循環語句
WHILE條件表達式BEGIN循環體語句系列…[BREAK]……[CONTINUE]……END執行過程:先計算判斷條件表達式的值若條件為真則執行BEGIN…END之間的循環體語句系列,執行到END時返回到WHILE再次判斷條件表達式的值。若條件為假,則直接跳過BEGIN…END不執行循環。若在執行循環體時遇到BREAK語句,則無條件跳出BEGIN…END。若在執行循環體時遇到CONTINUE語句,則結束本輪循環,不再執行之后的循環體語句,返回到WHILE再次判斷條件表達式的值。T-SQL流程控制語句4、CASE結構CASE結構用于多條件分支選擇,可以完成計算多個條件并為每個條件返回單個值。支持兩種格式:(1)簡單CASE…END表達式
CASE測試表達式WHEN常量值1THEN結果表達式1[{WHEN常量值2THEN結果表達式2}[…n]][ELSE結果表達式n]END功能:根據測試表達式的值得到一個對應值。執行過程:先計算測試表達式的值,將測試表達式的值按順序依次與WHEN指定的各個常量值進行比較;如果找到了一個相等常量值,則整個CASE表達式取相應THEN指定的結果表達式的值,之后不再比較,跳出CASE…END;如果找不到相等的常量值,則取ELSE指定的結果表達式n;如果找不到相等的常量值也沒有使用ELSE,則返回NULL。T-SQL流程控制語句(2)搜索CASE…END表達式CASEWHEN條件表達式1THEN結果表達式1[{WHEN條件表達式2THEN結果表達式2}[…n]][ELSE結果表達式n]END功能:根據某個條件得到一個對應值。注意:搜索CASE表達式與簡單CASE表達式的語法區別是CASE后沒有測試表達式,WHEN指定的不是常量值而是條件表達式。執行過程:按順序依次判斷WHEN指定條件表達式的值,遇到第一個為真的條件表達式,則整個CASE表達式取對應THEN指定的結果表達式的值,之后不再比較,結束并跳出CASE…END。如果找不到為真的條件表達式,則取ELSE指定的結果表達式n。如果找不到為真的條件表達式也沒有使用ELSE,則返回NULL。T-SQL流程控制語句5waitfor等待語句
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 貴州盛華職業學院《Internet協議原理》2023-2024學年第二學期期末試卷
- 武漢工貿職業學院《核輻射測量方法》2023-2024學年第二學期期末試卷
- 安徽農業大學《參數估計與系統辨識》2023-2024學年第二學期期末試卷
- 天津外國語大學濱海外事學院《身邊的化學》2023-2024學年第二學期期末試卷
- 鄭州旅游職業學院《流體機械CAD》2023-2024學年第二學期期末試卷
- 駐馬店幼兒師范高等專科學校《乳液聚合》2023-2024學年第二學期期末試卷
- 湖南工業大學《第四紀地質與地貌學》2023-2024學年第二學期期末試卷
- 南京師范大學中北學院《電視節目策劃與編導》2023-2024學年第二學期期末試卷
- 暨南大學《三維技術基礎》2023-2024學年第二學期期末試卷
- 南通理工學院《影視導演基礎》2023-2024學年第二學期期末試卷
- 航空服務禮儀與溝通考核試卷
- 中外運社招在線測評題
- 《有機化學:糖》課件
- 【專項訓練】相似三角形五大模型+訓練(共45題)(原卷版+解析)
- 11《杠桿》教學設計-2023-2024學年科學五年級下冊人教鄂教版
- TJSHLW 001-2024 土壤修復管控工程全過程監管數據接入規范
- 陽光心理-健康人生小學生心理健康主題班會課件
- 樂理知識考試題庫130題(含答案)
- 2023年廣東廣州中考滿分作文《一樣的舞臺不一樣的我》
- 2024年共青團入團積極分子團校結業考試試題庫及答案
- 小學五年級數學奧林匹克競賽試卷及答案
評論
0/150
提交評論