10.使用游標(biāo)的DML語(yǔ)句
一般情況下SELECT語(yǔ)句的查詢(xún)結(jié)果是記錄的集合而不是單個(gè)記錄,為此需要用游標(biāo)機(jī)制作為橋梁,把集合操作轉(zhuǎn)換為單記錄處理。與游標(biāo)有關(guān)的語(yǔ)句有四個(gè):
(1)定義游標(biāo)。游標(biāo)是與某一查詢(xún)結(jié)果相聯(lián)系的符號(hào)名。用DECLARE語(yǔ)句定義。這是一個(gè)說(shuō)明語(yǔ)句。與游標(biāo)相對(duì)應(yīng)的SELECT語(yǔ)句這時(shí)并不執(zhí)行。
(2)打開(kāi)(OPEN)游標(biāo)。打開(kāi)游標(biāo)語(yǔ)句使游標(biāo)處于活動(dòng)狀態(tài)。與游標(biāo)相應(yīng)的查詢(xún)語(yǔ)句被執(zhí)行。游標(biāo)指向查詢(xún)結(jié)果集中的第一個(gè)記錄之前。
(3)推進(jìn)(FETCH)游標(biāo)。把游標(biāo)向前推進(jìn)一個(gè)記錄,并把游標(biāo)指向的當(dāng)前記錄中的字段值取出,放到INTO子句后相應(yīng)的主變量中。FETCH語(yǔ)句常常用于循環(huán),以借助主語(yǔ)言功能逐一處理結(jié)果集中的數(shù)據(jù)。
(4)關(guān)閉(CLOSE)游標(biāo)。關(guān)閉游標(biāo),使它不再和原來(lái)的查詢(xún)結(jié)果相聯(lián)系。關(guān)閉了的游標(biāo)可以再次被打開(kāi),與新的查詢(xún)結(jié)果集相聯(lián)系。使用CURRENT形式的UPDATE和刪除語(yǔ)句應(yīng)注意:
(1)若游標(biāo)定義中的SELECT語(yǔ)句帶有UNION或ORDER BY子句,或者這個(gè)SELECT語(yǔ)句相當(dāng)于定義了一個(gè)不可更新的視圖,則不能用這兩個(gè)更新語(yǔ)句。
(2)若使用CURRENT形式的UPDATE語(yǔ)句,則游標(biāo)定義中要包括FOR UPDATE子句,指出更新的字段(SET子句中使用的字段)。因此,游標(biāo)定義語(yǔ)句的一般格式為:EXEC SQL DECLARE游標(biāo)名CURSOR FOR子查詢(xún)UNION子查詢(xún)…[FOR UPDATE OF字段名[,字段名]…|ORDER-BY-子句];
11.SQL的事務(wù)處理功能
(1)事務(wù)處理的概述所謂事務(wù)(Transaction)是指一系列動(dòng)作的組合,這些動(dòng)作被當(dāng)作一個(gè)整體來(lái)處理。這些動(dòng)作或者相繼都被執(zhí)行,或者什么也不做。在數(shù)據(jù)庫(kù)中,一個(gè)動(dòng)作是指一個(gè)SQL語(yǔ)句。事務(wù)是一組SQL語(yǔ)句組成的一個(gè)邏輯單位。要么這些SQL語(yǔ)句全部被按順序正確執(zhí)行,要么在某SQL語(yǔ)句執(zhí)行失敗時(shí),按照用戶(hù)要求,取消已執(zhí)行的SQL語(yǔ)句對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的修改。或者要么事務(wù)中SQL語(yǔ)句都被正確執(zhí)行,完成該事務(wù)對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的所有操作;或者要么相當(dāng)于一條SQL語(yǔ)句也未執(zhí)行,數(shù)據(jù)庫(kù)數(shù)據(jù)未做任何改動(dòng)。
(2)SQL語(yǔ)言的事務(wù)處理語(yǔ)句SQL語(yǔ)言有3條語(yǔ)句用于事務(wù)處理,它們是:
(1)Commit語(yǔ)句,對(duì)于正確執(zhí)行了的事務(wù)進(jìn)行提交,進(jìn)行提交即對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的修改永久化。同時(shí)還釋放事務(wù)和封鎖,標(biāo)志該事務(wù)結(jié)束。
(2)Save point語(yǔ)句,定義事務(wù)中的一個(gè)回滾保留點(diǎn),它是事務(wù)恢復(fù)時(shí)的一個(gè)標(biāo)記點(diǎn)。
(3)rollback語(yǔ)句,無(wú)論事務(wù)執(zhí)行的當(dāng)前位置在哪里,該語(yǔ)句的執(zhí)行要么取消事務(wù)執(zhí)行以來(lái)對(duì)數(shù)據(jù)庫(kù)的全部修改,要么取消至某個(gè)指定回滾點(diǎn)后對(duì)數(shù)據(jù)庫(kù)的全部修改。釋放自保留點(diǎn)之后的全部表或行的封鎖(沒(méi)有保留點(diǎn),相當(dāng)于回滾到事務(wù)開(kāi)始處,終止該事務(wù))。事務(wù)的恢復(fù)(回滾)是根據(jù)事務(wù)執(zhí)行前保存下的當(dāng)時(shí)數(shù)據(jù)庫(kù)狀態(tài)來(lái)實(shí)現(xiàn)的。一遇到rollback語(yǔ)句,就將數(shù)據(jù)庫(kù)中數(shù)據(jù)恢復(fù)到原來(lái)的狀態(tài),相當(dāng)于撤消事務(wù)中已執(zhí)行了的SQL語(yǔ)句。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |