數(shù)據(jù)庫(kù)原理與應(yīng)用:第7章 Transact-SQL程序設(shè)計(jì)_第1頁(yè)
數(shù)據(jù)庫(kù)原理與應(yīng)用:第7章 Transact-SQL程序設(shè)計(jì)_第2頁(yè)
數(shù)據(jù)庫(kù)原理與應(yīng)用:第7章 Transact-SQL程序設(shè)計(jì)_第3頁(yè)
數(shù)據(jù)庫(kù)原理與應(yīng)用:第7章 Transact-SQL程序設(shè)計(jì)_第4頁(yè)
數(shù)據(jù)庫(kù)原理與應(yīng)用:第7章 Transact-SQL程序設(shè)計(jì)_第5頁(yè)
已閱讀5頁(yè),還剩37頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、數(shù)據(jù)庫(kù)原理與應(yīng)用數(shù)據(jù)庫(kù)原理與應(yīng)用第七講第七講 Transact-SQLTransact-SQL程序設(shè)計(jì)程序設(shè)計(jì)1 注釋注釋2 變量變量3 運(yùn)算符運(yùn)算符4 函數(shù)函數(shù)5 流程控制語(yǔ)句流程控制語(yǔ)句 1 注釋注釋 注釋是程序代碼中不執(zhí)行的文本字符串(也注釋是程序代碼中不執(zhí)行的文本字符串(也稱為注解)。在稱為注解)。在SQL Server中,可以使用兩種類型中,可以使用兩種類型的注釋字符:一種是的注釋字符:一種是ANSI標(biāo)準(zhǔn)的注釋符標(biāo)準(zhǔn)的注釋符“-”,它用,它用于單行注釋;另一種是與于單行注釋;另一種是與C語(yǔ)言相同的程序注釋符語(yǔ)言相同的程序注釋符號(hào),即號(hào),即“/* */”。 2 變量變量變量是一種語(yǔ)言中

2、必不可少的組成部分。變量是一種語(yǔ)言中必不可少的組成部分。Transact-SQL語(yǔ)言中有兩種形式的變量,一種語(yǔ)言中有兩種形式的變量,一種是用戶自己定義的局部變量,另外一種是系統(tǒng)提是用戶自己定義的局部變量,另外一種是系統(tǒng)提供的全局變量。供的全局變量。1. 局部變量局部變量利用局部變量可以保存程序執(zhí)行過(guò)程中的中間結(jié)果,保存由存儲(chǔ)過(guò)程返回的數(shù)據(jù)值等。(1)局部變量的定義 必須先用DECLARE命令定義后才可以使用。DECLAER local_variable data_type n (2)局部變量的賦值方法 SET local_variable = expression 或者SELECT local

3、_variable = expression ,.n 2. 全局變量全局變量 全局變量是全局變量是SQL Server系統(tǒng)內(nèi)部使用的變量,系統(tǒng)內(nèi)部使用的變量,其作用范圍并不僅僅局限于某一程序,而是任何其作用范圍并不僅僅局限于某一程序,而是任何程序均可以隨時(shí)調(diào)用。全局變量通常存儲(chǔ)一些程序均可以隨時(shí)調(diào)用。全局變量通常存儲(chǔ)一些SQL Server的配置設(shè)定值和統(tǒng)計(jì)數(shù)據(jù)。用戶可的配置設(shè)定值和統(tǒng)計(jì)數(shù)據(jù)。用戶可以在程序中用全局變量來(lái)測(cè)試系統(tǒng)的設(shè)定值或者以在程序中用全局變量來(lái)測(cè)試系統(tǒng)的設(shè)定值或者是是Transact-SQL命令執(zhí)行后的狀態(tài)值。命令執(zhí)行后的狀態(tài)值。 使用全局變量時(shí)應(yīng)該注意以下幾點(diǎn):使用全局變量

4、時(shí)應(yīng)該注意以下幾點(diǎn): 全局變量不是由用戶的程序定義的,它們是在服務(wù)全局變量不是由用戶的程序定義的,它們是在服務(wù)器級(jí)定義的。器級(jí)定義的。用戶只能使用預(yù)先定義的全局變量。用戶只能使用預(yù)先定義的全局變量。引用全局變量時(shí),必須以標(biāo)記符引用全局變量時(shí),必須以標(biāo)記符“”開頭。開頭。局部變量的名稱不能與全局變量的名稱相同,否則局部變量的名稱不能與全局變量的名稱相同,否則會(huì)在應(yīng)用程序中出現(xiàn)不可預(yù)測(cè)的結(jié)果。會(huì)在應(yīng)用程序中出現(xiàn)不可預(yù)測(cè)的結(jié)果。 常用的全局變量常用的全局變量ErrorRowCount Identity3 運(yùn)算符運(yùn)算符 運(yùn)算符是一些符號(hào),它們能夠用來(lái)執(zhí)行算術(shù)運(yùn)算、運(yùn)算符是一些符號(hào),它們能夠用來(lái)執(zhí)行算術(shù)

5、運(yùn)算、字符串連接、賦值以及在字段、常量和變量之間進(jìn)字符串連接、賦值以及在字段、常量和變量之間進(jìn)行比較。在行比較。在SQL Server 2000中,運(yùn)算符主要有以中,運(yùn)算符主要有以下六大類:算術(shù)運(yùn)算符、賦值運(yùn)算符、位運(yùn)算符、下六大類:算術(shù)運(yùn)算符、賦值運(yùn)算符、位運(yùn)算符、比較運(yùn)算符、邏輯運(yùn)算符以及字符串串聯(lián)運(yùn)算符。比較運(yùn)算符、邏輯運(yùn)算符以及字符串串聯(lián)運(yùn)算符。1算術(shù)運(yùn)算符算術(shù)運(yùn)算符 算術(shù)運(yùn)算符可以在兩個(gè)表達(dá)式上執(zhí)行數(shù)學(xué)運(yùn)算術(shù)運(yùn)算符可以在兩個(gè)表達(dá)式上執(zhí)行數(shù)學(xué)運(yùn)算,這兩個(gè)表達(dá)式可以是數(shù)字?jǐn)?shù)據(jù)類型分類的任何算,這兩個(gè)表達(dá)式可以是數(shù)字?jǐn)?shù)據(jù)類型分類的任何數(shù)據(jù)類型。算術(shù)運(yùn)算符包括加(數(shù)據(jù)類型。算術(shù)運(yùn)算符包括加(

6、+)、減()、減()、)、乘(乘(*)、除()、除(/)和取模()和取模(%)。)。 2賦值運(yùn)算符賦值運(yùn)算符Transact-SQL 中只有一個(gè)賦值運(yùn)算符,中只有一個(gè)賦值運(yùn)算符,即等號(hào)(即等號(hào)(=)。賦值運(yùn)算符使我們能夠?qū)?shù)據(jù))。賦值運(yùn)算符使我們能夠?qū)?shù)據(jù)值指派給特定的對(duì)象。另外,還可以使用賦值指派給特定的對(duì)象。另外,還可以使用賦值運(yùn)算符在列標(biāo)題和為列定義值的表達(dá)式之值運(yùn)算符在列標(biāo)題和為列定義值的表達(dá)式之間建立關(guān)系。間建立關(guān)系。3位運(yùn)算符位運(yùn)算符位運(yùn)算符使我們能夠在整型位運(yùn)算符使我們能夠在整型數(shù)據(jù)或者二進(jìn)制數(shù)據(jù)(數(shù)據(jù)或者二進(jìn)制數(shù)據(jù)(image 數(shù)數(shù)據(jù)類型除外)之間執(zhí)行位操作。據(jù)類型除外)之間執(zhí)

7、行位操作。此外,在位運(yùn)算符左右兩側(cè)的操此外,在位運(yùn)算符左右兩側(cè)的操作數(shù)不能同時(shí)是二進(jìn)制數(shù)據(jù)。作數(shù)不能同時(shí)是二進(jìn)制數(shù)據(jù)。 表表2-1 位運(yùn)算符位運(yùn)算符 運(yùn)運(yùn) 算算 符符 含含 義義 &(按位(按位 AND)按位按位 AND(兩個(gè)操作數(shù))。(兩個(gè)操作數(shù))。|(按位(按位 OR)按位按位 OR(兩個(gè)操作數(shù))。(兩個(gè)操作數(shù))。(按位互斥(按位互斥 OR)按位互斥按位互斥 OR(兩個(gè)操作數(shù))。(兩個(gè)操作數(shù))。4比較運(yùn)算符比較運(yùn)算符比較運(yùn)算符用于比較兩個(gè)表達(dá)式的大小或比較運(yùn)算符用于比較兩個(gè)表達(dá)式的大小或是否相同,其比較的結(jié)果是布爾值,即是否相同,其比較的結(jié)果是布爾值,即TRUE(表示表達(dá)式的結(jié)果為

8、真)、(表示表達(dá)式的結(jié)果為真)、FALSE(表示表(表示表達(dá)式的結(jié)果為假)以及達(dá)式的結(jié)果為假)以及UNKNOWN。除了。除了 text、ntext 或或 image 數(shù)據(jù)類型的表達(dá)式外,比較運(yùn)算數(shù)據(jù)類型的表達(dá)式外,比較運(yùn)算符可以用于所有的表達(dá)式。符可以用于所有的表達(dá)式。 5邏輯運(yùn)算符邏輯運(yùn)算符邏輯運(yùn)算符可以把多個(gè)邏輯表邏輯運(yùn)算符可以把多個(gè)邏輯表達(dá)式連接起來(lái)。邏輯運(yùn)算符包括達(dá)式連接起來(lái)。邏輯運(yùn)算符包括AND、OR和和NOT等運(yùn)算符。邏輯運(yùn)等運(yùn)算符。邏輯運(yùn)算符和比較運(yùn)算符一樣,返回帶有算符和比較運(yùn)算符一樣,返回帶有 TRUE 或或 FALSE 值的布爾數(shù)據(jù)類型。值的布爾數(shù)據(jù)類型。6字符串串聯(lián)運(yùn)算符

9、字符串串聯(lián)運(yùn)算符字符串串聯(lián)運(yùn)算符允許通字符串串聯(lián)運(yùn)算符允許通過(guò)加號(hào)過(guò)加號(hào) (+) 進(jìn)行字符串串聯(lián),進(jìn)行字符串串聯(lián),這個(gè)加號(hào)即被稱為字符串串聯(lián)這個(gè)加號(hào)即被稱為字符串串聯(lián)運(yùn)算符。例如對(duì)于語(yǔ)句運(yùn)算符。例如對(duì)于語(yǔ)句SELECT abc+def,其結(jié)果,其結(jié)果為為abcdef。運(yùn)算符的優(yōu)先等級(jí)從高到低如下所示運(yùn)算符的優(yōu)先等級(jí)從高到低如下所示 括號(hào):();括號(hào):();乘、除、求模運(yùn)算符:乘、除、求模運(yùn)算符:*、/、%;加減運(yùn)算符:加減運(yùn)算符:+、- ;比較運(yùn)算符:比較運(yùn)算符:=、=、=、!=、!、!;位運(yùn)算符:位運(yùn)算符:、&、|;邏輯運(yùn)算符:邏輯運(yùn)算符:NOT;邏輯運(yùn)算符:邏輯運(yùn)算符:AND;邏輯

10、運(yùn)算符:邏輯運(yùn)算符:OR。4 函數(shù)函數(shù)在在Transact-SQL語(yǔ)言中,函數(shù)被用來(lái)執(zhí)行一些特殊的運(yùn)算以語(yǔ)言中,函數(shù)被用來(lái)執(zhí)行一些特殊的運(yùn)算以支持支持SQL Server的標(biāo)準(zhǔn)命令。的標(biāo)準(zhǔn)命令。Transact-SQL 編程語(yǔ)言提供了三種編程語(yǔ)言提供了三種函數(shù):函數(shù): 行集函數(shù):行集函數(shù)可以在行集函數(shù):行集函數(shù)可以在Transact-SQL語(yǔ)句中當(dāng)作表引語(yǔ)句中當(dāng)作表引用。用。 聚合函數(shù):聚合函數(shù)用于對(duì)一組值執(zhí)行計(jì)算并返回一個(gè)單一聚合函數(shù):聚合函數(shù)用于對(duì)一組值執(zhí)行計(jì)算并返回一個(gè)單一的值。的值。 標(biāo)量函數(shù):標(biāo)量函數(shù)用于對(duì)傳遞給它的一個(gè)或者多個(gè)參數(shù)值標(biāo)量函數(shù):標(biāo)量函數(shù)用于對(duì)傳遞給它的一個(gè)或者多個(gè)參數(shù)

11、值進(jìn)行處理和計(jì)算,并返回一個(gè)單一的值。進(jìn)行處理和計(jì)算,并返回一個(gè)單一的值。 SQL Server中最常用的幾種函數(shù)中最常用的幾種函數(shù) 字符串函數(shù)字符串函數(shù)日期和時(shí)間函數(shù)日期和時(shí)間函數(shù)數(shù)學(xué)函數(shù)數(shù)學(xué)函數(shù)轉(zhuǎn)換函數(shù)轉(zhuǎn)換函數(shù)系統(tǒng)函數(shù)系統(tǒng)函數(shù)聚合函數(shù)聚合函數(shù)其它函數(shù)其它函數(shù) 字符串函數(shù)字符串函數(shù)字符串函數(shù)可以對(duì)二進(jìn)制數(shù)據(jù)、字符串和表達(dá)式字符串函數(shù)可以對(duì)二進(jìn)制數(shù)據(jù)、字符串和表達(dá)式執(zhí)行不同的運(yùn)算,大多數(shù)字符串函數(shù)只能用于執(zhí)行不同的運(yùn)算,大多數(shù)字符串函數(shù)只能用于char和和varchar數(shù)據(jù)類型以及明確轉(zhuǎn)換成數(shù)據(jù)類型以及明確轉(zhuǎn)換成char和和varchar的數(shù)據(jù)類型,少數(shù)幾個(gè)字符串函數(shù)也可以用于的數(shù)據(jù)類型,少數(shù)

12、幾個(gè)字符串函數(shù)也可以用于binary和和varbinary數(shù)據(jù)類型。此外,某些字符串函數(shù)據(jù)類型。此外,某些字符串函數(shù)還能夠處理數(shù)還能夠處理text、ntext、image數(shù)據(jù)類型的數(shù)據(jù)。數(shù)據(jù)類型的數(shù)據(jù)。 字符串函數(shù)的分類:字符串函數(shù)的分類:基本字符串函數(shù):基本字符串函數(shù):UPPER、LOWER、SPACE、REPLICATE、STUFF、REVERSE、LTRIM、RTRIM。字符串查找函數(shù):字符串查找函數(shù):CHARINDEX、PATINDEX。長(zhǎng)度和分析函數(shù):長(zhǎng)度和分析函數(shù):DATALENGTH、SUBSTRING、RIGHT。轉(zhuǎn)換函數(shù):轉(zhuǎn)換函數(shù):ASCH、CHAR、STR、SOUNDEX、

13、DIFFERENCE。 2日期和時(shí)間函數(shù)日期和時(shí)間函數(shù)日期和時(shí)間函數(shù)用于對(duì)日期和時(shí)間日期和時(shí)間函數(shù)用于對(duì)日期和時(shí)間數(shù)據(jù)進(jìn)行各種不同的處理和運(yùn)算,數(shù)據(jù)進(jìn)行各種不同的處理和運(yùn)算,并返回一個(gè)字符串、數(shù)字值或日期并返回一個(gè)字符串、數(shù)字值或日期和時(shí)間值。在和時(shí)間值。在SQL Server 2000中,中,日期和時(shí)間函數(shù)的類型如表日期和時(shí)間函數(shù)的類型如表2-5所所示;另外,表示;另外,表2-6列出了日期類型列出了日期類型的名稱、縮寫形式以及可接受的值。的名稱、縮寫形式以及可接受的值。表表2-5 日期和時(shí)間函數(shù)的類型日期和時(shí)間函數(shù)的類型函函 數(shù)數(shù)參參 數(shù)數(shù)DATEADD(datepart,number,da

14、te)DATEDIFF(datepart,date1,date2)DATENAME(datepart,date)DATEPART(datepart,date)DAY(date)GETDATE()MONTH(date)YEAR( date )從從GETDATE函數(shù)返回的日期中函數(shù)返回的日期中提取月份數(shù)。提取月份數(shù)。 SELECT DATEPART(month, GETDATE() AS Month Number運(yùn)行結(jié)果為:運(yùn)行結(jié)果為:Month Number-4 從日期從日期 04/12/2006 中返回月份數(shù)、天數(shù)和年份中返回月份數(shù)、天數(shù)和年份數(shù)。數(shù)。SELECT MONTH(04/12/20

15、06), DAY(04/12/2006),YEAR(04/12/2006)運(yùn)行結(jié)果為:運(yùn)行結(jié)果為:- - -4 12 20063數(shù)學(xué)函數(shù)數(shù)學(xué)函數(shù)數(shù)學(xué)函數(shù)用于對(duì)數(shù)字表達(dá)式進(jìn)行數(shù)學(xué)函數(shù)用于對(duì)數(shù)字表達(dá)式進(jìn)行數(shù)學(xué)運(yùn)算并返回運(yùn)算結(jié)果。數(shù)學(xué)數(shù)學(xué)運(yùn)算并返回運(yùn)算結(jié)果。數(shù)學(xué)函數(shù)可以對(duì)函數(shù)可以對(duì)SQL Server提供的數(shù)提供的數(shù)字?jǐn)?shù)據(jù)(字?jǐn)?shù)據(jù)(decimal、integer、float、real、money、smallmoney、smallint 和和 tinyint)進(jìn)行處理。)進(jìn)行處理。 在同一表達(dá)式中使用在同一表達(dá)式中使用CEILING()、()、FLOOR()、()、ROUND()函數(shù)。()函數(shù)。sel

16、ect ceiling(13.4), floor(13.4), round(13.4567,3)運(yùn)行結(jié)果為:運(yùn)行結(jié)果為:- - -14 13 13.45704轉(zhuǎn)換函數(shù)轉(zhuǎn)換函數(shù)一般情況下,一般情況下,SQL Server會(huì)自動(dòng)處理某些數(shù)據(jù)類型會(huì)自動(dòng)處理某些數(shù)據(jù)類型的轉(zhuǎn)換。例如,如果比較的轉(zhuǎn)換。例如,如果比較 char 和和 datetime 表達(dá)式、表達(dá)式、smallint 和和 int 表達(dá)式、或不同長(zhǎng)度的表達(dá)式、或不同長(zhǎng)度的 char 表達(dá)式,表達(dá)式,SQL Server 可以將它們自動(dòng)轉(zhuǎn)換,這種轉(zhuǎn)換被稱為可以將它們自動(dòng)轉(zhuǎn)換,這種轉(zhuǎn)換被稱為隱性轉(zhuǎn)換。但是,無(wú)法由隱性轉(zhuǎn)換。但是,無(wú)法由SQL

17、Server自動(dòng)轉(zhuǎn)換的或自動(dòng)轉(zhuǎn)換的或者是者是SQL Server自動(dòng)轉(zhuǎn)換的結(jié)果不符合預(yù)期結(jié)果的,自動(dòng)轉(zhuǎn)換的結(jié)果不符合預(yù)期結(jié)果的,就需要使用轉(zhuǎn)換函數(shù)做顯示轉(zhuǎn)換。轉(zhuǎn)換函數(shù)有兩個(gè):就需要使用轉(zhuǎn)換函數(shù)做顯示轉(zhuǎn)換。轉(zhuǎn)換函數(shù)有兩個(gè):CONVERT和和CAST。CONVERT和和CAST函數(shù)函數(shù)C A S T ( e x p r e s s i o n A S data_type )CONVERT函數(shù)允許用戶把表達(dá)式從一函數(shù)允許用戶把表達(dá)式從一種數(shù)據(jù)類型轉(zhuǎn)換成另一種數(shù)據(jù)類型,還種數(shù)據(jù)類型轉(zhuǎn)換成另一種數(shù)據(jù)類型,還允許把日期轉(zhuǎn)換成不同的樣式。其語(yǔ)法允許把日期轉(zhuǎn)換成不同的樣式。其語(yǔ)法形式為:形式為:CONVERT

18、 (data_type(length),expression ,style)USE pubsSELECT title, ytd_salesFROM titlesWHERE CAST(ytd_sales AS char(20) LIKE 15% AND type = trad_cook運(yùn)行結(jié)果為:運(yùn)行結(jié)果為:Title ytd_sales-Fifty Years in Buckingham Palace Kitchens 150965系統(tǒng)函數(shù)系統(tǒng)函數(shù)系統(tǒng)函數(shù)用于返回有關(guān)系統(tǒng)函數(shù)用于返回有關(guān)SQL Server系統(tǒng)、用戶、數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)對(duì)象的系統(tǒng)、用戶、數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)對(duì)象的信息。系統(tǒng)函數(shù)可以讓用戶

19、在得到信信息。系統(tǒng)函數(shù)可以讓用戶在得到信息后,使用條件語(yǔ)句,根據(jù)返回的信息后,使用條件語(yǔ)句,根據(jù)返回的信息進(jìn)行不同的操作。與其它函數(shù)一樣,息進(jìn)行不同的操作。與其它函數(shù)一樣,可以在可以在SELECT語(yǔ)句的語(yǔ)句的SELECT和和WHERE子句以及表達(dá)式中使用系統(tǒng)子句以及表達(dá)式中使用系統(tǒng)函數(shù)。函數(shù)。 返回返回 Northwind 數(shù)據(jù)庫(kù)的數(shù)據(jù)庫(kù)的 Employees 表表中的首列的名稱。中的首列的名稱。USE NorthwindSELECT COL_NAME(OBJECT_ID(Employees), 1)運(yùn)行結(jié)果為:運(yùn)行結(jié)果為:EmployeeID6聚合函數(shù)聚合函數(shù) 聚合函數(shù)可以返回整個(gè)或者幾個(gè)列

20、聚合函數(shù)可以返回整個(gè)或者幾個(gè)列或者一個(gè)列的匯總數(shù)據(jù),它常用來(lái)或者一個(gè)列的匯總數(shù)據(jù),它常用來(lái)計(jì)算計(jì)算SELECT語(yǔ)句查詢的統(tǒng)計(jì)值。語(yǔ)句查詢的統(tǒng)計(jì)值。聚合函數(shù)經(jīng)常與聚合函數(shù)經(jīng)常與 SELECT 語(yǔ)句的語(yǔ)句的 GROUP BY 子句一同使用。子句一同使用。用戶自定義函數(shù)CREATE FUNCTION 創(chuàng)建用戶定義函數(shù),它是返回值的已保存的創(chuàng)建用戶定義函數(shù),它是返回值的已保存的 Transact-SQL 例程。用戶定義函數(shù)不例程。用戶定義函數(shù)不能用于執(zhí)行一組修改全局?jǐn)?shù)據(jù)庫(kù)狀態(tài)的操作。與系統(tǒng)函數(shù)一樣,用戶定義函數(shù)可以從能用于執(zhí)行一組修改全局?jǐn)?shù)據(jù)庫(kù)狀態(tài)的操作。與系統(tǒng)函數(shù)一樣,用戶定義函數(shù)可以從查詢中喚醒調(diào)

21、用。也可以像存儲(chǔ)過(guò)程一樣,通過(guò)查詢中喚醒調(diào)用。也可以像存儲(chǔ)過(guò)程一樣,通過(guò) EXECUTE 語(yǔ)句執(zhí)行。語(yǔ)句執(zhí)行。用戶定義函數(shù)用用戶定義函數(shù)用 ALTER FUNCTION 修改,用修改,用 DROP FUNCTION 除去。除去。CREATE FUNCTION owner_name. function_name ( parameter_name AS scalar_parameter_data_type = default ,.n ) RETURNS scalar_return_data_type WITH , .n AS BEGIN function_body RETURN scalar_ex

22、pressionEND5 流程控制語(yǔ)句流程控制語(yǔ)句流程控制語(yǔ)句是指那些用來(lái)控制程序流程控制語(yǔ)句是指那些用來(lái)控制程序執(zhí)行和流程分支的命令,在執(zhí)行和流程分支的命令,在SQL Server 2000中,流程控制語(yǔ)句主要中,流程控制語(yǔ)句主要用來(lái)控制用來(lái)控制SQL語(yǔ)句、語(yǔ)句塊或者存儲(chǔ)語(yǔ)句、語(yǔ)句塊或者存儲(chǔ)過(guò)程的執(zhí)行流程。過(guò)程的執(zhí)行流程。 使用BEGINEND可以將多條T-SQL語(yǔ)句封裝起來(lái),構(gòu)成一個(gè)獨(dú)立的語(yǔ)句塊。BEGIN關(guān)鍵字表示語(yǔ)句塊的開始,END關(guān)鍵字表示語(yǔ)句塊的結(jié)束,它們必須成對(duì)出現(xiàn)。BEGINEND的語(yǔ)法格式如下:BEGIN sql_statement | statement_block END

23、Begin EndIFELSE IFELSE語(yǔ)句可以控制程序按條件執(zhí)行。當(dāng)IF關(guān)鍵字后的條件滿足(布爾表達(dá)式返回TRUE 時(shí)),則在執(zhí)行IF關(guān)鍵字及其條件之后的T-SQL 語(yǔ)句。否則,就執(zhí)行ELSE關(guān)鍵字后的T-SQL語(yǔ)句(若ELSE部分存在)。IFELSE語(yǔ)句的語(yǔ)法格式如下:IF Boolean_expression sql_statement | statement_block ELSE sql_statement | statement_block 查詢課程號(hào)為“105237”的課程的平均分是否超過(guò)了85分,若超過(guò),則輸出考出了高分的信息。USE EducationalGODECLARE Course_ID varchar(10)SELECT Course_ID = 105237 /* 查詢的課程號(hào) */ IF ( SELECT AVG(Grade) FROM Grade WHERE CourseID = Course_ID ) 85/* 平均分大于85分 */BEGIN SELECT Course_ID = CourseName /* 從課程信息表中取課程名 */ FRO

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論