Oracle的游标

在PL/SQL块中执行SELECT、INSERT、DELETE和UPDATE语句时,ORACLE会在内存中为其分配上下文区(Context Area),即缓冲区。游标是指向该区的一个指针,或是命名一个工作区(Work Area),或是一种结构化数据类型。它供了一种对具有多行数据查询结果集中的每一行数据分别进行单独处理的方法,是设计嵌入式SQL语句的应用程序的常用编程方式。因此,引入了游标的概念。
使用游标的四个步骤:定义申明游标、打开游标、遍历游标、关闭游标。
游标的四个属性:%isopen、%Found、%NotFound、%rowcount。
在实际中游标通常与循环结合,下面举几个游标遍历的例题。
1.遍历xs表中的xh和zxf

DECLARE
      v_xh char(6);
       v_zxf number(2);
       CURSOR XS_CUR3 IS SELECT XH,ZXF FROM XS;
BEGIN
      OPEN XS_CUR3;
      FETCH XS_CUR3 INTO v_xh,v_zxf;
 	  WHILE XS_CUR3%FOUND
      LOOP
      dbms_output.put_line(v_xh||v_zxf);
      FETCH XS_CUR3 INTO v_xh,v_zxf;
      END LOOP;
      CLOSE XS_CUR3;
END;

2.利用游标WHILE循环统计并输出scott.emp表各个部门的平均工资;若平均工资大于3000,则输出“该部门平均工资较高。”

DECLARE
  CURSOR c_dept_stat IS SELECT deptno,avg(sal) avgsal FROM scott.emp GROUP BY deptno;
  v_dept c_dept_stat%ROWTYPE;
BEGIN
  OPEN c_dept_stat;
  FETCH c_dept_stat INTO v_dept; 
  WHILE c_dept_stat%FOUND LOOP
       DBMS_OUTPUT.PUT_LINE('部门号为'||v_dept.deptno||' '||'平均工资为'||trunc(v_dept.avgsal,1));
       FETCH c_dept_stat INTO v_dept;
  END LOOP;
  CLOSE c_dept_stat;
END; 

3.利用FOR循环统计并输出各个部门的平均工资。(for循环中的变量不需要额外申明)

BEGIN
  FOR v_dept IN (SELECT deptno,avg(sal) avgsal FROM scott.emp GROUP BY deptno)
  LOOP
    DBMS_OUTPUT.PUT_LINE(v_dept.deptno||' '||v_dept.avgsal);
  END LOOP; 
END; 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值