版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
T-SQL批處理和流程控制課程安排批處理T-SQL基礎(chǔ)begin...endif...else...while循環(huán)case分支waitfor語句批處理
所謂批處理是指從客戶機傳遞到服務(wù)器上的一組完整的數(shù)據(jù)和SQL指令。在一個批處理中,可以只包含一條SQL指令,也可以包含多條指令。批處理的所有語句被當(dāng)作一個整體,而被成批地分析、編譯和執(zhí)行,若這一批處理中存在一個語法錯誤,則所有的語句都無法通過編譯。所有的批處理指令以GO作為結(jié)束的標(biāo)志,當(dāng)編譯器讀到GO時,它就會把GO前面的所有指令當(dāng)作一個批處理,并包裝成一個數(shù)據(jù)包發(fā)送給服務(wù)器。T-SQL基礎(chǔ)一、注釋語句
--:一行注釋(注釋的內(nèi)容不超過一行)
/**/:一段注釋(當(dāng)注釋的內(nèi)容超過一行)二、輸出語句:PRINT語句。
PRINT語句把用戶定義的消息返回客戶端,其基本語句格式如下所示:
PRINT<字符串表達(dá)式>T-SQL基礎(chǔ):變量
變量指的是在程序運行過程中值可以發(fā)生變化的量。
SQL分為兩種類型的變量:全局變量和局部變量。其中全局變量是系統(tǒng)已經(jīng)定義好的變量,主要反映SQL數(shù)據(jù)庫的操作狀態(tài)。全局變量名稱以@@開頭;局部變量由用戶定義,主要用于保存運算結(jié)果,局部變量的名稱必須以@開頭。標(biāo)識符的命名常規(guī)標(biāo)識符應(yīng)遵守以下的命名規(guī)則:標(biāo)識符長度可以為1-128個字符。對于本地臨時表,標(biāo)識符最多可以有116個字符。標(biāo)識符的首字符必須為Unicode3.2標(biāo)準(zhǔn)所定義的字母或_、@、#符號。標(biāo)識符第一個字符后面的字符可以為Unicode3.2標(biāo)準(zhǔn)所定義的字符、數(shù)字或@、#、$、_符號。標(biāo)識符內(nèi)不能嵌入空格或其他特殊字符。標(biāo)識符不能與SQLServer中的保留關(guān)鍵字同名。T-SQL基礎(chǔ):變量和運算符局部變量
聲明變量:T-SQL中使用DECLARE語句聲明變量,并在聲明后將變量的值初始化為NULL。在一個DECLARE語句中可以同時聲明多個局部變量,它們相互之間用逗號分隔。DECLARE語句的基本語句格式如下:
DECLARE<@變量名1><數(shù)據(jù)類型>[,<@變量名2><數(shù)據(jù)類型>……]T-SQL基礎(chǔ):變量和運算符變量賦值
用SET、SELECT給局部變量賦值
語法格式:SET@局部變量=表達(dá)式
SELECT{@局部變量=表達(dá)式}[,…n]SET只能給一個變量賦值,而SELECT可以給多個變量賦值。兩種格式可以通用,建議首選使用SET,而不推薦使用SELECT語句。
表達(dá)式中可以包含SELECT語句子查詢,但只能是集合函數(shù)
返回的單值。且必須用圓括號括起來。
SELECT也可以直接使用查詢的單值結(jié)果給局部變量賦值。如:SELECT@局部變量=表達(dá)式或字段名FROM表名WHERE條件T-SQL基礎(chǔ):變量和運算符局部變量的顯示:
SELECT<@變量名表>
PRINT<@變量名>局部變量的作用域:
在一個批處理、一個存儲過程或一個觸發(fā)器內(nèi),其生命周期從定義開始到它遇到的第一個GO語句或者到存儲過程、觸發(fā)器的結(jié)尾結(jié)束,即局部變量只在當(dāng)前的批處理、存儲過程、觸發(fā)器中有效。
如果在批處理、存儲過程、觸發(fā)器中使用其他批處理、存儲過程、觸發(fā)器定義的變量,則系統(tǒng)出現(xiàn)錯誤并提示“必須聲明變量”。T-SQL基礎(chǔ):全局變量全局變量全局變量是由系統(tǒng)提供的有確定值的變量,用戶不能自己定義全局變量,也不能用SET語句來修改全局變量的值。系統(tǒng)全局變量都是以@@開頭的,全局變量實際上是一些特殊的不需要參數(shù)、也不需要加括號調(diào)用的函數(shù),可直接返回特定的值。例如:@@error:其值為最后一次執(zhí)行錯誤的SQL語句產(chǎn)生的錯誤代碼@@max_connections:其值為SQLServer允許多用戶同時連接的最大數(shù)@@connections:SQLServer最近一次啟動后已連接或嘗試連接的次數(shù)@@version:本地SQLServer服務(wù)器的版本信息T-SQL流程控制語句
T-SQL語言與其它高級語言一樣,提供了可以控制程序執(zhí)行流程的語句。使用這些流程控制語句可以更好地組織和控制程序的流程。
1、順序控制語句BEGIN…END語句塊
BEGIN語句1語句2…END不論多少個語句,放在BEGIN…END中間就構(gòu)成一個獨立的語句塊,被系統(tǒng)當(dāng)作一個整體單元來處理。條件的某個分支或循環(huán)體語句中,如果要執(zhí)行兩個以上的復(fù)合語句,則必須將它們放在BEGIN…END中間。T-SQL流程控制語句2、條件判斷語法格式:if
邏輯表達(dá)式{語句|語句塊}[else{語句|語句塊}]作用:按條件控制程序的執(zhí)行。當(dāng)條件滿足時,則在執(zhí)行條件之后的T-SQL語句。否則,就執(zhí)行else后的T-SQL語句(若ELSE部分存在)。T-SQL流程控制語句3、WHILE循環(huán)語句
WHILE條件表達(dá)式BEGIN循環(huán)體語句系列…[BREAK]……[CONTINUE]……END執(zhí)行過程:先計算判斷條件表達(dá)式的值若條件為真則執(zhí)行BEGIN…END之間的循環(huán)體語句系列,執(zhí)行到END時返回到WHILE再次判斷條件表達(dá)式的值。若條件為假,則直接跳過BEGIN…END不執(zhí)行循環(huán)。若在執(zhí)行循環(huán)體時遇到BREAK語句,則無條件跳出BEGIN…END。若在執(zhí)行循環(huán)體時遇到CONTINUE語句,則結(jié)束本輪循環(huán),不再執(zhí)行之后的循環(huán)體語句,返回到WHILE再次判斷條件表達(dá)式的值。T-SQL流程控制語句4、CASE結(jié)構(gòu)CASE結(jié)構(gòu)用于多條件分支選擇,可以完成計算多個條件并為每個條件返回單個值。支持兩種格式:(1)簡單CASE…END表達(dá)式
CASE測試表達(dá)式WHEN常量值1THEN結(jié)果表達(dá)式1[{WHEN常量值2THEN結(jié)果表達(dá)式2}[…n]][ELSE結(jié)果表達(dá)式n]END功能:根據(jù)測試表達(dá)式的值得到一個對應(yīng)值。執(zhí)行過程:先計算測試表達(dá)式的值,將測試表達(dá)式的值按順序依次與WHEN指定的各個常量值進(jìn)行比較;如果找到了一個相等常量值,則整個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ù)某個條件得到一個對應(yīng)值。注意:搜索CASE表達(dá)式與簡單CASE表達(dá)式的語法區(qū)別是CASE后沒有測試表達(dá)式,WHEN指定的不是常量值而是條件表達(dá)式。執(zhí)行過程:按順序依次判斷WHEN指定條件表達(dá)式的值,遇到第一個為真的條件表達(dá)式,則整個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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 蚌埠醫(yī)學(xué)院《色彩靜物》2023-2024學(xué)年第一學(xué)期期末試卷
- 2024年環(huán)境可持續(xù)發(fā)展產(chǎn)品供方合同3篇
- 2024幼兒園門衛(wèi)智能化管理聘用合同3篇
- 2024年甲乙雙方關(guān)于特許經(jīng)營權(quán)轉(zhuǎn)讓的委托開發(fā)合同
- 2025版分公司承包運營管理合同6篇
- 2025白酒行業(yè)人才引進(jìn)與培養(yǎng)合同3篇
- 2024年物業(yè)服務(wù)成本合同3篇
- 2025版班主任新手帶教與教育教學(xué)改革協(xié)議3篇
- 2025年度醫(yī)療設(shè)施包工包料裝修施工合同范本2篇
- 二零二五年度一張打印耗材采購合同含臨時代用及調(diào)整規(guī)定2篇
- 2024年度寵物用品銷售代理合同范本3篇
- 湖南2025年湖南生物機電職業(yè)技術(shù)學(xué)院招聘35人歷年參考題庫(頻考版)含答案解析
- 部隊物業(yè)服務(wù)投標(biāo)方案
- 銷售單 代合同范例
- 2024年3月天津第一次高考英語試卷真題答案解析(精校打?。?/a>
- 2024譯林版七年級英語上冊單詞(帶音標(biāo))
- 品管圈PDCA案例-普外科提高甲狀腺手術(shù)患者功能鍛煉合格率
- 2024-2025學(xué)年語文二年級上冊 部編版期末測試卷(含答案)
- 期末模擬卷 2024-2025學(xué)年人教版數(shù)學(xué)六年級上冊(含答案)
- 2025年消防救援設(shè)施操作員職業(yè)技能資格知識考試題庫與答案
- 電玩城租賃經(jīng)營合同
評論
0/150
提交評論