PL/SQL用光標查詢多條記錄
發(fā)表時間:2024-02-17 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]PL/SQL光標為程序提供了從數(shù)據(jù)庫中選擇多行數(shù)據(jù),然后對每行數(shù)據(jù)單獨進行處理的方法,它為Oracle提供了一種指示和控制SQL處理的各個階段的方法。我將認為您已經(jīng)對PL/SQL有一定的了解。通過本文,您將學會:光標的創(chuàng)建 光標的處理 定義和使用光標屬性 一、 什么是光標Oracle使用兩種光標:...
PL/SQL光標為程序提供了從數(shù)據(jù)庫中選擇多行數(shù)據(jù),然后對每行數(shù)據(jù)單獨進行處理的方法,它為Oracle提供了一種指示和控制SQL處理的各個階段的方法。我將認為您已經(jīng)對PL/SQL有一定的了解。通過本文,您將學會:
光標的創(chuàng)建
光標的處理
定義和使用光標屬性
一、 什么是光標
Oracle使用兩種光標:顯式光標和隱式光標。不管語句返回多少條紀錄,PL/SQL為使用的每一條UPDATE、DELETE和INSERT等SQL命令隱式的聲明一個光標。(要管理SQL語句的處理,必須隱式的給它定義一個光標。)用戶聲明并使用顯示光標處理SELECT語句返回的多條記錄。顯示的定義光標一種結(jié)構(gòu),它使用戶能夠為特定的語句指定內(nèi)存區(qū)域,以便以后使用。
二、 光標的作用
當PL/SQL光標查詢返回多行數(shù)據(jù)時,這些記錄組被稱為活動集。Oracle將這種活動集存儲在您創(chuàng)建的顯示定義的已命名的光標中。Oracle光標是一種用于輕松的處理多行數(shù)據(jù)的機制,沒有光標,Oracle開發(fā)人員必須單獨地、顯式地取回并管理光標查詢選擇的每一條記錄。
光標的另一項功能事,它包含一個跟蹤當前訪問的記錄的指針,這使您的程序能夠一次處理多條記錄。
三、 使用顯示光標的基本方法
步驟如下:
聲明光標
打開光標
從光標中取回數(shù)據(jù)
關(guān)閉光標
1、聲明光標
聲明光標的語法如下:
DECLARE cursor_name
Is
SELECT statement
其中,cursor_name是您給光標指定的名稱;SELECT statement是給光標活動集返回記錄的查詢。
聲明光標完成了下面兩個目的:
給光標命名;
將一個查詢與光標關(guān)聯(lián)起來。
值得注意的是,必須在PL/SQL塊的聲明部分聲明光標;給光標指定的名稱是一個未聲明的標識符,而不是一個PL/SQL變量,不能給光標名稱賦值,也不能將它用在表達式中。PL/SQL塊使用這個名稱來引用光標查詢。
例:DECLARE
CURSOR c1
Is
SELECT VIEW_NAME FROM ALL_VIEWS
WHERE ROWNUM<=10;
另外還可以在光標定義語句中聲明光標的參數(shù),例:
CURSOR c1(view _nbr number)
Is
SELECT VIEW_NAME FROM ALL_VIEWS
WHERE ROWNUM<= view _nbr;
光標參數(shù)只對相應的光標是可見的,不能在光標范圍之外引用該光標的參數(shù)。如果試圖這樣做,Oracle將返回一個錯誤,指出該變量沒有定義。
2、打開光標
打開光標的語法如下:
OPEN cursor_name;
其中cursor_name是您以前定義的光標名稱。
打開光標將激活查詢并識別活動集,可是在執(zhí)行光標取回命令之前,并沒有真正取回記錄。OPEN命令還初始化了光標指針,使其指向活動集的第一條記錄。光標被打開后,直到關(guān)閉之前,取回到活動集的所有數(shù)據(jù)都是靜態(tài)的,換句話說,光標忽略所有在光標打開之后,對數(shù)據(jù)執(zhí)行的SQL DML命令(INSERT、UPDATE、DELETE和SELECT)。因此只有在需要時才打開它,要刷新活動集,只需關(guān)閉并重新打開光標即可。
3、從光標中取回數(shù)據(jù)
FETCH命令以每次一條記錄的方式取回活動集中的記錄。通常將FETCH命令和某種迭代處理結(jié)合起來使用,在迭代處理中,F(xiàn)ETCH命令每執(zhí)行一次,光標前進到活動集的下一條記錄。
FETCH命令的語法:
FETCH cursor_name INTO record_list;
其中,cursor_name是前面定義的光標的名稱;record_list是變量列表,它接受活動集中的列。FETCH命令將活動集的結(jié)果放置到這些變量中。
執(zhí)行FETCH命令后,活動集中的結(jié)果被取回到PL/SQL變量中,以便在PL/SQL塊中使用。每取回一條記錄,光標的指針就移向活動集的下一條記錄。
例:
FETCH C1 INTO VNAME;
WHILE C1%FOUND LOOP
DBMS_OUTPUT.PUT_LINE(TO_CHAR(C1%ROWCOUNT) ' ' VNAME);
END LOOP;
其中,使用屬性'%FOUND'使得當FETCH到達活動集的結(jié)尾時,不會引發(fā)異常。其它屬性及含義見下表:
屬性 含量
%FOUND 布爾型屬性,當最近一次該記錄時成功返回,則值為TRUE
%NOTFOUND 布爾型屬性,它的值總與%FOUND屬性的值相反
%ISOPEN 布爾型屬性,當光標是打開時返回TRUE
%ROWCOUNT 數(shù)字型屬性,返回已從光標中讀取的記錄數(shù)
屬性 含量
%FOUND 布爾型屬性,當最近一次該記錄時成功返回,則值為TRUE
%NOTFOUND 布爾型屬性,它的值總與%FOUND屬性的值相反
%ISOPEN 布爾型屬性,當光標是打開時返回TRUE
%ROWCOUNT 數(shù)字型屬性,返回已從光標中讀取的記錄數(shù)
4、關(guān)閉光標
CLOSE語句關(guān)閉以前打開的光標,使得活動集不確定。當用戶的程序或會話結(jié)束時,Oracle隱式關(guān)閉光標。光標被關(guān)閉后,就不能對它執(zhí)行任何操作了,否則將引發(fā)異常。
CLOSE語句的語法是:
CLOSE cursor_name;
其中,cursor_name是以前打開的光標的名稱。
完整的程序代碼如下:
DECLARE
CURSOR C1 IS SELECT VIEW_NAME FROM ALL_VIEWS
WHERE ROWNUM<=10
ORDER BY VIEW_NAME;
VNAME VARCHAR2(40);
BEGIN
OPEN C1;
FETCH C1 INTO VNAME;
WHILE C1%FOUND LOOP
DBMS_OUTPUT.PUT_LINE(TO_CHAR(C1%ROWCOUNT) '' VNAME);
END LOOP;
END;
……CLOSE C1;
四、 小結(jié)
光標是一種結(jié)構(gòu),能夠以一次一條記錄的方式處理多行查詢的結(jié)果.為每條DML語句創(chuàng)建隱式光標,而顯式光標是由用戶創(chuàng)建的,以便處理返回多條記錄的查詢。而且,通過消除反復地分析代碼,光標提高了代碼的處理速度。