版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(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語(yǔ)句批處理
所謂批處理是指從客戶(hù)機(jī)傳遞到服務(wù)器上的一組完整的數(shù)據(jù)和SQL指令。在一個(gè)批處理中,可以只包含一條SQL指令,也可以包含多條指令。批處理的所有語(yǔ)句被當(dāng)作一個(gè)整體,而被成批地分析、編譯和執(zhí)行,若這一批處理中存在一個(gè)語(yǔ)法錯(cuò)誤,則所有的語(yǔ)句都無(wú)法通過(guò)編譯。所有的批處理指令以GO作為結(jié)束的標(biāo)志,當(dāng)編譯器讀到GO時(shí),它就會(huì)把GO前面的所有指令當(dāng)作一個(gè)批處理,并包裝成一個(gè)數(shù)據(jù)包發(fā)送給服務(wù)器。T-SQL基礎(chǔ)一、注釋語(yǔ)句
--:一行注釋?zhuān)ㄗ⑨尩膬?nèi)容不超過(guò)一行)
/**/:一段注釋?zhuān)ó?dāng)注釋的內(nèi)容超過(guò)一行)二、輸出語(yǔ)句:PRINT語(yǔ)句。
PRINT語(yǔ)句把用戶(hù)定義的消息返回客戶(hù)端,其基本語(yǔ)句格式如下所示:
PRINT<字符串表達(dá)式>T-SQL基礎(chǔ):變量
變量指的是在程序運(yùn)行過(guò)程中值可以發(fā)生變化的量。
SQL分為兩種類(lèi)型的變量:全局變量和局部變量。其中全局變量是系統(tǒng)已經(jīng)定義好的變量,主要反映SQL數(shù)據(jù)庫(kù)的操作狀態(tài)。全局變量名稱(chēng)以@@開(kāi)頭;局部變量由用戶(hù)定義,主要用于保存運(yùn)算結(jié)果,局部變量的名稱(chēng)必須以@開(kāi)頭。標(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語(yǔ)句聲明變量,并在聲明后將變量的值初始化為NULL。在一個(gè)DECLARE語(yǔ)句中可以同時(shí)聲明多個(gè)局部變量,它們相互之間用逗號(hào)分隔。DECLARE語(yǔ)句的基本語(yǔ)句格式如下:
DECLARE<@變量名1><數(shù)據(jù)類(lèi)型>[,<@變量名2><數(shù)據(jù)類(lèi)型>……]T-SQL基礎(chǔ):變量和運(yùn)算符變量賦值
用SET、SELECT給局部變量賦值
語(yǔ)法格式:SET@局部變量=表達(dá)式
SELECT{@局部變量=表達(dá)式}[,…n]SET只能給一個(gè)變量賦值,而SELECT可以給多個(gè)變量賦值。兩種格式可以通用,建議首選使用SET,而不推薦使用SELECT語(yǔ)句。
表達(dá)式中可以包含SELECT語(yǔ)句子查詢(xún),但只能是集合函數(shù)
返回的單值。且必須用圓括號(hào)括起來(lái)。
SELECT也可以直接使用查詢(xún)的單值結(jié)果給局部變量賦值。如:SELECT@局部變量=表達(dá)式或字段名FROM表名WHERE條件T-SQL基礎(chǔ):變量和運(yùn)算符局部變量的顯示:
SELECT<@變量名表>
PRINT<@變量名>局部變量的作用域:
在一個(gè)批處理、一個(gè)存儲(chǔ)過(guò)程或一個(gè)觸發(fā)器內(nèi),其生命周期從定義開(kāi)始到它遇到的第一個(gè)GO語(yǔ)句或者到存儲(chǔ)過(guò)程、觸發(fā)器的結(jié)尾結(jié)束,即局部變量只在當(dāng)前的批處理、存儲(chǔ)過(guò)程、觸發(fā)器中有效。
如果在批處理、存儲(chǔ)過(guò)程、觸發(fā)器中使用其他批處理、存儲(chǔ)過(guò)程、觸發(fā)器定義的變量,則系統(tǒng)出現(xiàn)錯(cuò)誤并提示“必須聲明變量”。T-SQL基礎(chǔ):全局變量全局變量全局變量是由系統(tǒng)提供的有確定值的變量,用戶(hù)不能自己定義全局變量,也不能用SET語(yǔ)句來(lái)修改全局變量的值。系統(tǒng)全局變量都是以@@開(kāi)頭的,全局變量實(shí)際上是一些特殊的不需要參數(shù)、也不需要加括號(hào)調(diào)用的函數(shù),可直接返回特定的值。例如:@@error:其值為最后一次執(zhí)行錯(cuò)誤的SQL語(yǔ)句產(chǎn)生的錯(cuò)誤代碼@@max_connections:其值為SQLServer允許多用戶(hù)同時(shí)連接的最大數(shù)@@connections:SQLServer最近一次啟動(dòng)后已連接或嘗試連接的次數(shù)@@version:本地SQLServer服務(wù)器的版本信息T-SQL流程控制語(yǔ)句
T-SQL語(yǔ)言與其它高級(jí)語(yǔ)言一樣,提供了可以控制程序執(zhí)行流程的語(yǔ)句。使用這些流程控制語(yǔ)句可以更好地組織和控制程序的流程。
1、順序控制語(yǔ)句BEGIN…END語(yǔ)句塊
BEGIN語(yǔ)句1語(yǔ)句2…END不論多少個(gè)語(yǔ)句,放在BEGIN…END中間就構(gòu)成一個(gè)獨(dú)立的語(yǔ)句塊,被系統(tǒng)當(dāng)作一個(gè)整體單元來(lái)處理。條件的某個(gè)分支或循環(huán)體語(yǔ)句中,如果要執(zhí)行兩個(gè)以上的復(fù)合語(yǔ)句,則必須將它們放在BEGIN…END中間。T-SQL流程控制語(yǔ)句2、條件判斷語(yǔ)法格式:if
邏輯表達(dá)式{語(yǔ)句|語(yǔ)句塊}[else{語(yǔ)句|語(yǔ)句塊}]作用:按條件控制程序的執(zhí)行。當(dāng)條件滿(mǎn)足時(shí),則在執(zhí)行條件之后的T-SQL語(yǔ)句。否則,就執(zhí)行else后的T-SQL語(yǔ)句(若ELSE部分存在)。T-SQL流程控制語(yǔ)句3、WHILE循環(huán)語(yǔ)句
WHILE條件表達(dá)式BEGIN循環(huán)體語(yǔ)句系列…[BREAK]……[CONTINUE]……END執(zhí)行過(guò)程:先計(jì)算判斷條件表達(dá)式的值若條件為真則執(zhí)行BEGIN…END之間的循環(huán)體語(yǔ)句系列,執(zhí)行到END時(shí)返回到WHILE再次判斷條件表達(dá)式的值。若條件為假,則直接跳過(guò)BEGIN…END不執(zhí)行循環(huán)。若在執(zhí)行循環(huán)體時(shí)遇到BREAK語(yǔ)句,則無(wú)條件跳出BEGIN…END。若在執(zhí)行循環(huán)體時(shí)遇到CONTINUE語(yǔ)句,則結(jié)束本輪循環(huán),不再執(zhí)行之后的循環(huán)體語(yǔ)句,返回到WHILE再次判斷條件表達(dá)式的值。T-SQL流程控制語(yǔ)句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í)行過(guò)程:先計(jì)算測(cè)試表達(dá)式的值,將測(cè)試表達(dá)式的值按順序依次與WHEN指定的各個(gè)常量值進(jìn)行比較;如果找到了一個(gè)相等常量值,則整個(gè)CASE表達(dá)式取相應(yīng)THEN指定的結(jié)果表達(dá)式的值,之后不再比較,跳出CASE…END;如果找不到相等的常量值,則取ELSE指定的結(jié)果表達(dá)式n;如果找不到相等的常量值也沒(méi)有使用ELSE,則返回NULL。T-SQL流程控制語(yǔ)句(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á)式的語(yǔ)法區(qū)別是CASE后沒(méi)有測(cè)試表達(dá)式,WHEN指定的不是常量值而是條件表達(dá)式。執(zhí)行過(guò)程:按順序依次判斷WHEN指定條件表達(dá)式的值,遇到第一個(gè)為真的條件表達(dá)式,則整個(gè)CASE表達(dá)式取對(duì)應(yīng)THEN指定的結(jié)果表達(dá)式的值,之后不再比較,結(jié)束并跳出CASE…END。如果找不到為真的條件表達(dá)式,則取ELSE指定的結(jié)果表達(dá)式n。如果找不到為真的條件表達(dá)式也沒(méi)有使用ELSE,則返回NULL。T-SQL流程控制語(yǔ)句5waitfor等待語(yǔ)句
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年度年福建省高校教師資格證之高等教育心理學(xué)高分通關(guān)題型題庫(kù)附解析答案
- 山西省煤礦建設(shè)六個(gè)標(biāo)準(zhǔn)目錄3篇
- 高三綜評(píng)自我陳述報(bào)告
- 期貨入門(mén)知識(shí)
- 地板磚買(mǎi)賣(mài)協(xié)議2024年
- 2024商業(yè)借款保障協(xié)議規(guī)范
- 新人教版數(shù)學(xué)第二十五章-概率初步全章教學(xué)設(shè)計(jì)
- 2024年制定商品銷(xiāo)售返購(gòu)協(xié)議樣例
- 2024年度房產(chǎn)項(xiàng)目融資安排協(xié)議
- 2024年化建筑工程施工承包協(xié)議
- 《應(yīng)用統(tǒng)計(jì)學(xué)》(第4版)-自測(cè)試卷及答案B卷
- 《賦能年輕一代、共筑韌性未來(lái)》國(guó)際減災(zāi)日主題班會(huì)教案
- 10.1愛(ài)護(hù)身體(課件)-2024-2025學(xué)年統(tǒng)編版道德與法治七年級(jí)上冊(cè)
- 2024口腔執(zhí)業(yè)醫(yī)師聘用合同
- 2024-2025學(xué)年人教版生物七年級(jí)上冊(cè)期中備考重點(diǎn)知識(shí)
- 低空經(jīng)濟(jì)招商引資策略與措施
- 四川省成都市2023-2024學(xué)年高一上學(xué)期語(yǔ)文期中考試試卷(含答案)
- 第10課《我們不亂扔》(課件)-部編版道德與法治二年級(jí)上冊(cè)
- 陽(yáng)光心理-健康人生小學(xué)生心理健康主題班會(huì)課件
- 少兒美術(shù)幼兒園課件- 4-6歲 《秋梨》
- 小學(xué)六年級(jí)數(shù)學(xué)計(jì)算題100道(含答案)
評(píng)論
0/150
提交評(píng)論