ORACLE 动态游标的使用

简介: ORACLE 动态游标的使用

动态游标可以遍历动态的表,

格式:

TYPE 游标类型 IS REF CURSOR; --定义一个动态游标 
游标名  游标类型;

如果查询的表的数据不同的,动态变化的,这时候可以用动态游标。

需要注意的是,动态游标的定义,

在普通存储过程中:需要放在 is 后面的第一行。

动态游标通过:open 游标 for 字符串,形式使用,遍历。

CREATE OR REPLACE PROCEDURE P_TEST_SQL IS
  TYPE REF_CURSOR_TYPE IS REF CURSOR; --定义一个动态游标
  TABLENAME VARCHAR2(200) DEFAULT 'ess_client';
  V_SQL     VARCHAR2(1000);
  MOBILE    VARCHAR2(15);
  USRS      REF_CURSOR_TYPE;
BEGIN
  --使用连接符拼接成一条完整SQL
  V_SQL := 'select usrmsisdn from ' || TABLENAME || ' where rownum < 11';
  --打开游标
  OPEN USRS FOR V_SQL;
  LOOP
    FETCH USRS
      INTO MOBILE;
    EXIT WHEN USRS%NOTFOUND;
    INSERT INTO TMP (USRMSISDN) VALUES (MOBILE);
  END LOOP;
  CLOSE USRS;
  COMMIT;
END P_TEST_SQL;

下面是一个实例

CREATE OR REPLACE PROCEDURE DDGZ1 --订单跟踪

(

 P_FLAG VARCHAR, --订单类型

 P_OPERATE VARCHAR, --操作类型

 P_BH VARCHAR --传入的编号ID

 )

 IS

  TYPE REF_CURSOR_TYPE IS REF CURSOR;

  V_CUR_CKD REF_CURSOR_TYPE;

BEGIN

  OPEN V_CUR_CKD FOR 'select v_ERP,v_DRP,v_jxsmc,v_jxs,v_DWMC,v_czr,v_jlsj from tmp_DDGZ1';

  FETCH V_CUR_CKD
    INTO V_ERP, V_DRP, V_JXSMC, V_JXS, V_DWMC, V_CZR, V_JZSJ;

  WHILE V_CUR_CKD%FOUND

   LOOP

    INSERT INTO DRPDDGZJL2
      (JLID, DRP, ERP, JXS, JXSMC, JLSJ, GZJL, CZR, BHID)
    VALUES
      (SYS_GUID(),
       V_DRP,
       V_ERP,
       V_JXS,
       V_JXSMC,
       V_JZSJ,
       V_DWMC || '受托代销成品库接收订单,组织发货',
       V_CZR,
       '出库单' || P_BH);

    FETCH V_CUR_CKD
      INTO V_ERP, V_DRP, V_JXSMC, V_JXS, V_DWMC, V_CZR, V_JZSJ;

  END LOOP;

  CLOSE V_CUR_CKD;

END;
相关文章
|
4月前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL隐式游标:数据的“自动导游”与“轻松之旅”
【4月更文挑战第19天】Oracle PL/SQL中的隐式游标是自动管理的数据导航工具,简化编程工作,尤其适用于简单查询和DML操作。它自动处理数据访问,提供高效、简洁的代码,但不适用于复杂场景。显式游标在需要精细控制时更有优势。了解并适时使用隐式游标,能提升数据处理效率,让开发更加轻松。
|
3月前
|
SQL Oracle 关系型数据库
Oracle游标的使用和优化技巧
Oracle游标的使用和优化技巧
|
2月前
|
SQL Oracle 关系型数据库
Oracle游标的定义与使用
Oracle游标的定义与使用
|
2月前
|
SQL Oracle 关系型数据库
Oracle游标的使用和优化技巧
Oracle游标的使用和优化技巧
|
3月前
|
SQL Oracle 关系型数据库
Oracle游标的定义与使用
Oracle游标的定义与使用
|
3月前
|
SQL Oracle 关系型数据库
Oracle游标的定义与使用技巧
Oracle游标的定义与使用技巧
|
2月前
|
Oracle 关系型数据库
oracle收集统计信息,游标失效时间
Dbms_stats Invalidates Cursors in Auto_invalidate mode
31 0
|
2月前
|
Oracle 关系型数据库
oracle收集统计信息,游标失效时间
Dbms_stats Invalidates Cursors in Auto_invalidate mode
27 0
|
2月前
|
SQL 存储 Oracle
Oracle数据库中游标的工作原理与优化方法
Oracle数据库中游标的工作原理与优化方法
|
3月前
|
SQL Oracle 关系型数据库
Oracle游标深入探讨
Oracle游标深入探讨