遊標的基本原理:
在Oracle中,在執行一個有SELECT、INSERT、UPDATE和DELETE語句PL/SQL塊時,Oracle會在記憶體中為其分配一個緩衝區,將執行結果放在這個緩衝區中,而遊標是該去的一個指標。
遊標分類:
靜態資料指標 動態資料指標。
靜態資料指標又分隱式遊標和顯示遊標。
顯示遊標的使用步驟:
1.聲明遊標
CURSOR cursor_name [(parameter[,parameter]...)]
[RETURN return_type] IS select_statement;
cursor_name指遊標的名稱
parameter用於為遊標指定輸入參數。在指定資料類型時,不能使用長度約束。例如NUMBER(4)、CHAR(10)等都是錯誤的。
return_type用於定義遊標提取的行的類型。
select_statement指遊標定義的查詢語句。
2.開啟遊標
OPEN cursor_name[(parameters)];
3.提取遊標
FETCH cursor_name INTO variables;
cursor_name值遊標的名稱
variables是變數名。
4.關閉遊標
CLOSE cursor_name;
顯示遊標的屬性:
%FOUND:只有在DML語句影響一行或多行時,%FOUND屬性才會返回TRUE。
%NOTFOUND:%NOTFOUND屬性與%FOUND屬性的作用正好相反。如果DML語句沒有影響任何行,則%NOTFOUND屬性返回TRUE。
%ROWCOUNT:%ROWCOUNT屬性返回DML語句影響的行數。如果DML語句沒有影響任何行,則%ROWCOUNT屬性將返回0。
%ISOPEN:%ISOPEN屬性返回遊標是否已開啟。
使用顯示遊標刪除或更新:
CURSOR cursor_name IS
select_statement FOR UPDATE [OF columns];
SELECT FOR UPDATE[OF columns]為更新查詢,鎖定選擇的行。
1.當選擇單標更新查詢時,可以省略OF子句。
2.當選擇多個表更新查詢時,被鎖定的行來源於OF子句後聲明的列所在的表中的行。