oracle sql游标

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;
 4.2 使用示例


5.使用游标更新或删除
5.1 语法
CURSOR cursor_name IS select_statement FOR UPDATE [OF column_reference] [NOWAIT];
在定义更新或删除游标时,必须要带有FOR UPDATE 字句,用于在游标结果集上加锁,OF字句用于在特定表上加锁,NOWAIT字句用于指定不等待锁。
5.2 使用示例



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值