數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案_第1頁(yè)
數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案_第2頁(yè)
數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案_第3頁(yè)
數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案_第4頁(yè)
數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案_第5頁(yè)
已閱讀5頁(yè),還剩8頁(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)介

數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程與觸發(fā)器試題及答案姓名:____________________

一、單項(xiàng)選擇題(每題2分,共10題)

1.存儲(chǔ)過(guò)程在數(shù)據(jù)庫(kù)中的作用不包括:

A.提高數(shù)據(jù)庫(kù)操作效率

B.限制用戶對(duì)數(shù)據(jù)的直接訪問(wèn)

C.實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)邏輯

D.提供用戶界面

2.以下哪個(gè)SQL語(yǔ)句用于創(chuàng)建存儲(chǔ)過(guò)程?

A.CREATETABLE

B.CREATEVIEW

C.CREATEPROCEDURE

D.CREATEINDEX

3.在存儲(chǔ)過(guò)程中,以下哪個(gè)關(guān)鍵字用于聲明一個(gè)變量?

A.DECLARE

B.DECLAREVariableNamedatatype

C.DECLAREVariableNamedatatype=value

D.DECLAREVariableNamedatatype;

4.在SQLServer中,觸發(fā)器通常用于:

A.檢查數(shù)據(jù)的完整性和安全性

B.實(shí)現(xiàn)數(shù)據(jù)的自動(dòng)備份

C.實(shí)現(xiàn)數(shù)據(jù)字典的更新

D.以上都是

5.以下哪個(gè)觸發(fā)器在插入數(shù)據(jù)時(shí)執(zhí)行?

A.AFTERINSERT

B.AFTERUPDATE

C.AFTERDELETE

D.INSTEADOFINSERT

6.在觸發(fā)器中,以下哪個(gè)函數(shù)用于獲取觸發(fā)操作發(fā)生之前的舊值?

A.GETDATE()

B.OLD

C.NEW

D.GETID()

7.以下哪個(gè)關(guān)鍵字用于定義觸發(fā)器的執(zhí)行時(shí)機(jī)?

A.TRIGGER

B.WHEN

C.ON

D.INSTEAD

8.在存儲(chǔ)過(guò)程中,以下哪個(gè)關(guān)鍵字用于結(jié)束一個(gè)循環(huán)?

A.END

B.EXIT

C.LEAVE

D.CONTINUE

9.在SQLServer中,以下哪個(gè)系統(tǒng)表用于存儲(chǔ)存儲(chǔ)過(guò)程信息?

A.INFORMATION_SCHEMA.PROCEDURES

B.INFORMATION_SCHEMA.VIEWS

C.INFORMATION_SCHEMA.TABLES

D.INFORMATION_SCHEMA.COLUMNS

10.在觸發(fā)器中,以下哪個(gè)關(guān)鍵字用于返回一個(gè)值?

A.RETURN

B.SELECT

C.VALUES

D.INSERT

二、多項(xiàng)選擇題(每題3分,共10題)

1.存儲(chǔ)過(guò)程的優(yōu)勢(shì)包括:

A.提高數(shù)據(jù)庫(kù)操作效率

B.提高代碼的可重用性

C.提高數(shù)據(jù)的安全性

D.簡(jiǎn)化數(shù)據(jù)庫(kù)操作流程

E.減少網(wǎng)絡(luò)傳輸數(shù)據(jù)量

2.以下哪些是存儲(chǔ)過(guò)程的組成部分?

A.聲明部分

B.執(zhí)行部分

C.異常處理部分

D.注釋部分

E.返回值部分

3.觸發(fā)器的類(lèi)型包括:

A.AFTER觸發(fā)器

B.INSTEADOF觸發(fā)器

C.BEFORE觸發(fā)器

D.INSTEADOFDELETE觸發(fā)器

E.INSTEADOFINSERT觸發(fā)器

4.在存儲(chǔ)過(guò)程中,可以使用以下哪些數(shù)據(jù)類(lèi)型?

A.整型

B.字符串型

C.日期型

D.數(shù)值型

E.二進(jìn)制型

5.觸發(fā)器可以用于:

A.實(shí)現(xiàn)數(shù)據(jù)的完整性約束

B.實(shí)現(xiàn)復(fù)雜的業(yè)務(wù)邏輯

C.實(shí)現(xiàn)數(shù)據(jù)的審計(jì)

D.實(shí)現(xiàn)數(shù)據(jù)的備份

E.實(shí)現(xiàn)數(shù)據(jù)的恢復(fù)

6.以下哪些是觸發(fā)器可能引發(fā)的錯(cuò)誤?

A.數(shù)據(jù)類(lèi)型不匹配

B.違反了完整性約束

C.觸發(fā)器邏輯錯(cuò)誤

D.系統(tǒng)資源不足

E.觸發(fā)器嵌套過(guò)深

7.在存儲(chǔ)過(guò)程中,可以使用以下哪些控制流語(yǔ)句?

A.IF...ELSE

B.CASE

C.WHILE

D.FOR

E.DECLARE

8.以下哪些是觸發(fā)器中常用的系統(tǒng)表?

A.INFORMATION_SCHEMA.TRIGGERS

B.INFORMATION_SCHEMA.COLUMNS

C.INFORMATION_SCHEMA.PROCEDURES

D.INFORMATION_SCHEMA.VIEWS

E.INFORMATION_SCHEMA.TABLES

9.在觸發(fā)器中,可以使用以下哪些操作?

A.插入數(shù)據(jù)

B.更新數(shù)據(jù)

C.刪除數(shù)據(jù)

D.查詢數(shù)據(jù)

E.調(diào)用存儲(chǔ)過(guò)程

10.以下哪些是觸發(fā)器可能遇到的問(wèn)題?

A.觸發(fā)器性能低下

B.觸發(fā)器邏輯錯(cuò)誤

C.觸發(fā)器嵌套過(guò)深

D.觸發(fā)器與業(yè)務(wù)邏輯沖突

E.觸發(fā)器維護(hù)困難

三、判斷題(每題2分,共10題)

1.存儲(chǔ)過(guò)程可以在客戶端直接調(diào)用,無(wú)需在數(shù)據(jù)庫(kù)中存儲(chǔ)其定義。(×)

2.觸發(fā)器可以在數(shù)據(jù)庫(kù)的任何表中創(chuàng)建,不受數(shù)據(jù)類(lèi)型限制。(√)

3.存儲(chǔ)過(guò)程中的變量在存儲(chǔ)過(guò)程結(jié)束后仍然存在。(×)

4.觸發(fā)器可以執(zhí)行與觸發(fā)事件無(wú)關(guān)的操作。(×)

5.在存儲(chǔ)過(guò)程中,可以使用SELECT語(yǔ)句檢索數(shù)據(jù)。(√)

6.觸發(fā)器可以用來(lái)實(shí)現(xiàn)數(shù)據(jù)的級(jí)聯(lián)更新和刪除。(√)

7.觸發(fā)器可以在存儲(chǔ)過(guò)程中調(diào)用其他存儲(chǔ)過(guò)程。(√)

8.存儲(chǔ)過(guò)程可以減少客戶端與服務(wù)器之間的通信次數(shù)。(√)

9.觸發(fā)器可以提高數(shù)據(jù)庫(kù)的安全性,因?yàn)樗梢韵拗朴脩魧?duì)數(shù)據(jù)的直接訪問(wèn)。(√)

10.在觸發(fā)器中,可以使用RETURN語(yǔ)句返回一個(gè)值,類(lèi)似于存儲(chǔ)過(guò)程中的RETURN語(yǔ)句。(√)

四、簡(jiǎn)答題(每題5分,共6題)

1.簡(jiǎn)述存儲(chǔ)過(guò)程和觸發(fā)器的主要區(qū)別。

2.解釋什么是觸發(fā)器中的NEW和OLD關(guān)鍵字,并說(shuō)明它們?cè)谟|發(fā)器中的作用。

3.描述如何在SQLServer中創(chuàng)建一個(gè)簡(jiǎn)單的觸發(fā)器,該觸發(fā)器在插入數(shù)據(jù)到某個(gè)表時(shí)自動(dòng)更新另一個(gè)表。

4.解釋在存儲(chǔ)過(guò)程中如何使用循環(huán)語(yǔ)句,并給出一個(gè)使用FOR循環(huán)的示例。

5.簡(jiǎn)述存儲(chǔ)過(guò)程中如何處理異常,并給出一個(gè)異常處理的示例代碼。

6.描述在觸發(fā)器中如何使用遞歸,并說(shuō)明遞歸觸發(fā)器的潛在問(wèn)題。

試卷答案如下

一、單項(xiàng)選擇題答案及解析:

1.D.提供用戶界面

解析:存儲(chǔ)過(guò)程主要用于封裝復(fù)雜的數(shù)據(jù)庫(kù)操作邏輯,提高操作效率,并不直接提供用戶界面。

2.C.CREATEPROCEDURE

解析:CREATEPROCEDURE是SQL語(yǔ)句中用于創(chuàng)建存儲(chǔ)過(guò)程的命令。

3.B.DECLAREVariableNamedatatype

解析:在存儲(chǔ)過(guò)程中聲明變量時(shí),使用DECLARE關(guān)鍵字,后跟變量名和數(shù)據(jù)類(lèi)型。

4.D.以上都是

解析:觸發(fā)器可以用于檢查數(shù)據(jù)的完整性和安全性,實(shí)現(xiàn)數(shù)據(jù)的自動(dòng)備份,更新數(shù)據(jù)字典等。

5.D.INSTEADOFINSERT

解析:INSTEADOFINSERT觸發(fā)器在插入數(shù)據(jù)時(shí)執(zhí)行,而不是執(zhí)行插入操作。

6.B.OLD

解析:在觸發(fā)器中,OLD關(guān)鍵字用于獲取觸發(fā)操作發(fā)生之前的舊值。

7.C.ON

解析:定義觸發(fā)器的執(zhí)行時(shí)機(jī)時(shí),使用ON關(guān)鍵字。

8.B.EXIT

解析:在存儲(chǔ)過(guò)程中,使用EXIT關(guān)鍵字來(lái)結(jié)束一個(gè)循環(huán)。

9.A.INFORMATION_SCHEMA.PROCEDURES

解析:INFORMATION_SCHEMA.PROCEDURES系統(tǒng)表用于存儲(chǔ)存儲(chǔ)過(guò)程信息。

10.A.RETURN

解析:在觸發(fā)器中,RETURN關(guān)鍵字用于返回一個(gè)值。

二、多項(xiàng)選擇題答案及解析:

1.A,B,C,D,E

解析:存儲(chǔ)過(guò)程的優(yōu)勢(shì)包括提高效率、可重用性、安全性、簡(jiǎn)化流程和減少網(wǎng)絡(luò)傳輸。

2.A,B,C,D,E

解析:存儲(chǔ)過(guò)程的組成部分包括聲明部分、執(zhí)行部分、異常處理部分、注釋部分和返回值部分。

3.A,B,C,D,E

解析:觸發(fā)器的類(lèi)型包括AFTER、INSTEADOF觸發(fā)器,以及它們的變體。

4.A,B,C,D,E

解析:在存儲(chǔ)過(guò)程中,可以使用整型、字符串型、日期型、數(shù)值型和二進(jìn)制型等數(shù)據(jù)類(lèi)型。

5.A,B,C,D,E

解析:觸發(fā)器可以用于實(shí)現(xiàn)數(shù)據(jù)的完整性約束、業(yè)務(wù)邏輯、審計(jì)、備份和恢復(fù)。

6.A,B,C,D,E

解析:觸發(fā)器可能引發(fā)的錯(cuò)誤包括數(shù)據(jù)類(lèi)型不匹配、違反完整性約束、邏輯錯(cuò)誤、系統(tǒng)資源不足和嵌套過(guò)深。

7.A,B,C,D

解析:在存儲(chǔ)過(guò)程中,可以使用IF...ELSE、CASE、WHILE和FOR等控制流語(yǔ)句。

8.A,B,C,D,E

解析:觸發(fā)器中常用的系統(tǒng)表包括INFORMATION_SCHEMA.TRIGGERS、COLUMNS、PROCEDURES、VIEWS和TABLES。

9.A,B,C,D,E

解析:在觸發(fā)器中,可以執(zhí)行插入、更新、刪除、查詢數(shù)據(jù)和調(diào)用存儲(chǔ)過(guò)程等操作。

10.A,B,C,D,E

解析:觸發(fā)器可能遇到的問(wèn)題包括性能低下、邏輯錯(cuò)誤、嵌套過(guò)深、與業(yè)務(wù)邏輯沖突和維護(hù)困難。

三、判斷題答案及解析:

1.×

解析:存儲(chǔ)過(guò)程在數(shù)據(jù)庫(kù)中存儲(chǔ)其定義,客戶端可以通過(guò)調(diào)用存儲(chǔ)過(guò)程來(lái)執(zhí)行其功能。

2.√

解析:觸發(fā)器中的NEW關(guān)鍵字用于獲取觸發(fā)操作發(fā)生之后的新值,OLD關(guān)鍵字用于獲取舊值。

3.×

解析:存儲(chǔ)過(guò)程中的變量在存儲(chǔ)過(guò)程結(jié)束后會(huì)消失,除非它們被定義為會(huì)話變量。

4.×

解析:觸發(fā)器只能在觸發(fā)事件發(fā)生時(shí)執(zhí)行,不能執(zhí)行與觸發(fā)事件無(wú)關(guān)的操作。

5.√

解析:在存儲(chǔ)過(guò)程中,可以使用SELECT語(yǔ)句檢索數(shù)據(jù),并將結(jié)果存儲(chǔ)在變量中或直接輸出。

6.√

解析:觸發(fā)器可以用來(lái)實(shí)現(xiàn)數(shù)據(jù)的級(jí)聯(lián)更新和刪除,確保數(shù)據(jù)的一致性。

7.√

解析:在存儲(chǔ)過(guò)程中,可以使用CALL語(yǔ)句調(diào)用其他存儲(chǔ)過(guò)程。

8.√

解析:存儲(chǔ)過(guò)程可以減少客戶端與服務(wù)器之間的通信次數(shù),提高效率。

9.√

解析:觸發(fā)器可以提高數(shù)據(jù)庫(kù)的安全性,因?yàn)樗梢韵拗朴脩魧?duì)數(shù)據(jù)的直接訪問(wèn)。

10.√

解析:在觸發(fā)器中,RETURN語(yǔ)句用于返回一個(gè)值,類(lèi)似于存儲(chǔ)過(guò)程中的RETURN語(yǔ)句。

四、簡(jiǎn)答題答案及解析:

1.存儲(chǔ)過(guò)程是預(yù)編譯的SQL語(yǔ)句集合,用于封裝復(fù)雜的數(shù)據(jù)庫(kù)操作邏輯,觸發(fā)器是數(shù)據(jù)庫(kù)表中特定事件發(fā)生時(shí)自動(dòng)執(zhí)行的SQL語(yǔ)句集合。主要區(qū)別在于存儲(chǔ)過(guò)程是獨(dú)立的程序單元,而觸發(fā)器是數(shù)據(jù)庫(kù)事件的一部分。

2.NEW關(guān)鍵字用于獲取觸發(fā)操作發(fā)生之后的新值,OLD關(guān)鍵字用于獲取舊值。在INSERT觸發(fā)器中,NEW用于引用新插入的行,而在UPDATE和DELETE觸發(fā)器中,OLD用于引用被修改或刪除的行。

3.在SQLServer中創(chuàng)建一個(gè)簡(jiǎn)單的觸發(fā)器,該觸發(fā)器在插入數(shù)據(jù)到某個(gè)表時(shí)自動(dòng)更新另一個(gè)表,可以使用以下SQL語(yǔ)句:

```

CREATETRIGGERUpdateAnotherTable

ONTargetTable

AFTERINSERT

AS

BEGIN

UPDATEAnotherTable

SETAnotherColumn=INSERTED.AnotherColumn

FROMINSERTED

WHEREINSERTED.PrimaryKey=AnotherTable.PrimaryKey

END

```

此觸發(fā)器在插入TargetTable的新數(shù)據(jù)后,將新數(shù)據(jù)更新到AnotherTable中。

4.在存儲(chǔ)過(guò)程中,可以使用循環(huán)語(yǔ)句來(lái)重復(fù)執(zhí)行一組SQL語(yǔ)句。以下是一個(gè)使用FOR循環(huán)的示例,用于計(jì)算1到10的和:

```

DECLARE@SumINT

SET@Sum=0

FOR@i=1TO10

BEGIN

SET@Sum=@Sum+@i

END

SELECT@SumASTotalSum

```

在這個(gè)例子中,循環(huán)變量@i從1增加到10,每次迭代都將@i的值加到@Sum變量上。

5.在存儲(chǔ)過(guò)程中處理異常,可以使用TRY...CATCH塊。以下是一個(gè)異常處理的示例:

```

BEGINTRY

--嘗試執(zhí)行的SQL語(yǔ)句

END

溫馨提示

  • 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 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)論