sql游标
当执行SELECT、INSERT、UPDATE以及DELETE语句时,Oracle Server会为这些SQL语句分配相应的上下文区,并且Oracle使用上下文区解析并执行相应的SQL语句,游标是指向上下文区的指针。在PL/SQL块中游标又包含 隐含游标和显式游标两种类型,其中隐含游标专门用于处理SELECT INTO、INSERT、UPDATE以及DELETE语句,也称为SQL游标;而显式游标用于处理SELECT语句返回的多行数据。1. 隐含游标:
1.1 隐含游标属性
* SQL%ISOPEN:该属性用于确定SQL游标是否已经打开。* SQL%FOUND:用于确定SQL语句执行是否成功。
* SQL%NOTFOUND:该属性用于确定语句是否不成功。
* SQL%ROWCOUNT:该属性用于返回SQL语句所作用的总计行数。
1.2 使用示例
2.显示游标:
2.1 使用显示游标
(1):定义游标CURSOR cursor_name IS select_statement;
(2):打开游标
OPEN cursor_name;
(3):提取数据
FETCH cursor_name INTO var1,var2,...;
(4):关闭游标
CLOSE cursor_name;
2.2 显示游标属性
* %ISOPEN* %FOUND
* %NOTFOUND
* %ROWCOUNT
2.3 使用示例
3.参数游标
3.1 使用参数
CURSOR cursor_name(parameter_name datatype) IS select_statement;
注意:当定义参数游标时,游标参数只能指定数据类型,而不能指定长度。
注意:当定义参数游标时,游标参数只能指定数据类型,而不能指定长度。
3.2 使用示例
4.游标FOR循环
4.1 语法
游标FOR循环是在PL/SQL块中使用游标的最简单方式,当使用游标FOR循环时,Oracle会隐含打开、提取并关闭游标。
FOR record_name IN cursor_name LOOP
statement1;
statement2;
END LOOP;
FOR record_name IN cursor_name LOOP
statement1;
statement2;
END LOOP;
4.2 使用示例
5.使用游标更新或删除
5.1 语法
CURSOR cursor_name IS select_statement FOR UPDATE [OF column_reference] [NOWAIT];
在定义更新或删除游标时,必须要带有FOR UPDATE 字句,用于在游标结果集上加锁,OF字句用于在特定表上加锁,NOWAIT字句用于指定不等待锁。