oracle存储过程中游标定义

1.游标的使用。看到的一段解释很好的概念,如下:
    游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。 
游标有两种类型:显式游标和隐式游标。在前述程序中用到的SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,系统都会使用一个隐式游标。但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多行多列的SELECT语句。 
游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。在我们进行insert、update、delete和select   value into  variable 的操作中,使用的是隐式游标。

隐式游标的属性 返回值类型意义 : 

SQL%ROWCOUNT    整型  代表DML语句成功执行的数据行数   
SQL%FOUND   布尔型 值为TRUE代表插入、删除、更新或单行查询操作成功   
SQL%NOTFOUND    布尔型 与SQL%FOUND属性返回值相反   
SQL%ISOPEN  布尔型 DML执行过程中为真,结束后为假  
2.隐士游标:

create or replace procedure prc_example (epo in number) as
BEGIN  
        UPDATE emp SET sal=sal+100 WHERE empno=epo;   
         IF SQL%FOUND THEN    
        DBMS_OUTPUT.PUT_LINE('成功修改雇员工资!');   
        COMMIT;    
        ELSE  
        DBMS_OUTPUT.PUT_LINE('修改雇员工资失败!');   
         END IF;    
        END; 

declare
e_number number;
begin
e_number:=7788;
prc_example(e_number);
 end;
3.显示游标:

使用游标查询所有编号为10 的员工名

create or replace procedure prc_example is
begin
    declare
    cursor emp_sor  is select ename,sal from emp where deptno=10;  
    cname emp.ename%type;     
    csal emp.sal%type;
 begin
   open emp_sor;       
   loop        
   fetch emp_sor into cname,csal;  --取游标的值给变量。             
   dbms_output.put_line('ename:'||cname);        
   exit when emp_sor%notfound;        
  end loop;         
  close emp_sor;     
 end;
end;
 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在Oracle存储过程可以使用游标来处理查询结果集。游标可以分为显式游标和隐式游标两种类型。显式游标是程序员明确声明的游标,可以通过控制游标来处理查询结果集。而隐式游标是在执行查询时自动创建的游标,由Oracle数据库引擎自动处理。\[1\] 在存储过程,可以使用无参游标来处理不需要参数的查询,例如遍历表的所有行。创建无参游标的示例代码如下: ``` DECLARE CURSOR 无所求 IS SELECT * FROM table_name; -- 定义游标变量 BEGIN -- 打开游标 OPEN 无所求; -- 循环读取游标数据 LOOP FETCH 无所求 INTO <列名>; EXIT WHEN 无所求%NOTFOUND; -- 处理数据 END LOOP; -- 关闭游标 CLOSE 无所求; END; ``` 在上述代码,无参游标定义为一个SELECT语句的结果集。然后,通过打开游标、循环读取游标数据、处理数据以及关闭游标的步骤来完成对查询结果集的处理。\[2\] 此外,存储过程还可以使用有参游标来处理需要参数的查询。有参游标的使用方式与无参游标类似,只是在定义游标时需要指定参数。例如,可以使用游标来查询指定部门的员工信息。\[3\] #### 引用[.reference_title] - *1* *2* [oracle 存储过程~游标](https://blog.csdn.net/weixin_63173847/article/details/131006394)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [oracle存储过程游标定义](https://blog.csdn.net/qq_37314497/article/details/89334563)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值