英語釋義
cursor簡介
計算機術語
當你在一個文本框或某種程式中輸入文字時,總有一個游標來顯示你將要輸入文字的位置。
現在大部分的游標都為一個小豎線,規則的閃動.而在DOS下有些游標則是短短的小橫線,同樣規則的閃動.現用的windows游標是一個圖像,可以是動態的也可以是靜態的,在不同情況下樣子也不同。
資料庫中的游標
什麼是游標
(要管理SQL語句的處理,必須隱式的給它定義一個游標。)用戶聲明並使用顯示游標處理SELECT語句返回的多條記錄。顯示的定義游標是一種結構,它使用戶能夠為特定的語句指定記憶體區域,以便以後使用。
游標的作用
當PL/SQL游標查詢返回多行數據時,這些記錄組被稱為活動集。Oracle將這種活動集存儲在您創建的顯示定義的已命名的游標中。Oracle游標是一種用於輕鬆的處理多行數據的機制,沒有游標,Oracle開發人員必須單獨地、顯示地取回並管理游標查詢選擇的每一條記錄。
游標的另一項功能事,它包含一個跟蹤當前訪問的記錄的指針,這使您的程式能夠一次處理多條記錄。
使用顯示游標的基本方法
步驟如下:
1、聲明游標
聲明游標的語法如下:
DECLAREcursor_name
Is
SELECTstatement
其中,cursor_name是您給游標指定的名稱;SELECTstatement是給游標活動集返回記錄的查詢。
聲明游標完成了下面兩個目的:
給游標命名;
將一個查詢與游標關聯起來。
值得注意的是,必須在PL/SQL塊的聲明部分聲明游標;給游標指定的名稱是一個未聲明的標識符,而不是一個PL/SQL變數,不能給游標名稱賦值,也不能將它用在表達式中。PL/SQL塊使用這個名稱來引用游標查詢。
例:DECLARE
CURSORc1
Is
SELECTVIEW_NAMEFROMALL_VIEWS
WHEREROWNUM<=10;
另外還可以在游標定義語句中聲明游標的參數,例:
CURSORc1(view_nbrnumber)
Is
SELECTVIEW_NAMEFROMALL_VIEWS
WHEREROWNUM<=view_nbr;
游標參數只對相應的游標是可見的,不能在游標範圍之外引用該游標的參數。如果試圖這樣做,Oracle將返回一個錯誤,指出該變數沒有定義。
2、打開游標
打開游標的語法如下:
OPENcursor_name;
其中cursor_name是您以前定義的游標名稱。
打開游標將激活查詢並識別活動集,可是在執行游標取回命令之前,並沒有真正取回記錄。OPEN命令還初始化了游標指針,使其指向活動集的第一條記錄。游標被打開後,直到關閉之前,取回到活動集的所有數據都是靜態的,換句話說,游標忽略所有在游標打開之後,對數據執行的SQLDML命令(INSERT、UPDATE、DELETE和SELECT)。因此只有在需要時才打開它,要刷新活動集,只需關閉並重新打開游標即可。
3、從游標中取回數據
FETCH命令以每次一條記錄的方式取回活動集中的記錄。通常將FETCH命令和某種疊代處理結合起來使用,在疊代處理中,FETCH命令每執行一次,游標前進到活動集的下一條記錄。
FETCH命令的語法:
FETCHcursor_nameINTOrecord_list;
其中,cursor_name是前面定義的游標的名稱;record_list是變數列表,它接受活動集中的列。FETCH命令將活動集的結果放置到這些變數中。
執行FETCH命令後,活動集中的結果被取回到PL/SQL變數中,以便在PL/SQL塊中使用。每取回一條記錄,游標的指針就移向活動集的下一條記錄。
例:
FETCHC1INTOVNAME;
WHILEC1%FOUNDLOOP
DBMS_OUTPUT.PUT_LINE(TO_CHAR(C1%ROWCOUNT)||''||VNAME);
ENDLOOP;
其中,使用屬性'%FOUND'使得當FETCH到達活動集的結尾時,不會引發異常。其它屬性及含義見下表:
屬性含量
%FOUND布爾型屬性,當最近一次該記錄時成功返回,則值為TRUE
%NOTFOUND布爾型屬性,它的值總與%FOUND屬性的值相反
%ISOPEN布爾型屬性,當游標是打開時返回TRUE
%ROWCOUNT數字型屬性,返回已從游標中讀取的記錄數
屬性含量
%FOUND布爾型屬性,當最近一次該記錄時成功返回,則值為TRUE
%NOTFOUND布爾型屬性,它的值總與%FOUND屬性的值相反
%ISOPEN布爾型屬性,當游標是打開時返回TRUE
%ROWCOUNT數字型屬性,返回已從游標中讀取的記錄數
4、關閉游標
CLOSE語句關閉以前打開的游標,使得活動集不確定。當用戶的程式或會話結束時,Oracle隱式關閉游標。游標被關閉後,就不能對它執行任何操作了,否則將引發異常。
CLOSE語句的語法是:
CLOSEcursor_name;
其中,cursor_name是以前打開的游標的名稱。
完整的程式代碼如下:
DECLARE
CURSORC1ISSELECTVIEW_NAMEFROMALL_VIEWS
WHEREROWNUM<=10
ORDERBYVIEW_NAME;
VNAMEVARCHAR2(40);
BEGIN
OPENC1;
FETCHC1INTOVNAME;
WHILEC1%FOUNDLOOP
DBMS_OUTPUT.PUT_LINE(TO_CHAR(C1%ROWCOUNT)||''||VNAME);
ENDLOOP;
END;
……CLOSEC1;
小結
游標是一種結構,能夠以一次一條記錄的方式處理多行查詢的結果.為每條DML語句創建隱式游標,而顯示游標是由用戶創建的,以便處理返回多條記錄的查詢。而且,通過消除反覆地分析代碼,游標提高了代碼的處理速度。