V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
coolicer
V2EX  ›  程序员

查了半天,不知道怎么调用 oracle 的存储过程,带游标

  •  
  •   coolicer · Jun 9, 2015 · 3043 views
    This topic created in 3976 days ago, the information mentioned may be changed or developed.

    在网上查到了这样的

    declare
    I_NAME VARCHAR2(10) := 'xxx';
    I_IS_USING VARCHAR2(2) := '1';
    v_cursor SYS_REFCURSOR;
    v_count NUMBER;
    r_emp emp%rowtype; ?? 这里不理解
    begin
    PROC_T_PROCEDURE_OBJ_LIST(I_NAME,I_IS_USING, v_cursor,v_count);
    loop
    fetch v_cursor into r_emp;
    exit when v_cursor%NOTFOUNRD;
    dbms_output.put_line('name: ' || r_emp.NAME || ' info: ' || r_emp.INFO || ' using: ' || r_emp.IS_USING);
    end loop;
    close v_cursor;
    end;

    9 replies    2015-06-11 07:48:45 +08:00
    ayumilove
        1
    ayumilove  
       Jun 9, 2015
    %TYPE 和 %ROWTYPE 类似
    百度一下 oracle %ROWTYPE 很多解释
    ayumilove
        2
    ayumilove  
       Jun 9, 2015
    你想用什么调用
    coolicer
        3
    coolicer  
    OP
       Jun 9, 2015
    @ayumilove 我想在 sql 编辑器那里运行,看结果集输出
    sun1991
        4
    sun1991  
       Jun 9, 2015
    显示结果的地方不一样. dbms_output的输出不在普通的查询结果集里面, 而是在专门的dbms output里面的.
    ayumilove
        5
    ayumilove  
       Jun 10, 2015
    如果仅是为了调试使用,直接在DBMS output 中查看结果就可以了(注意开启)。
    我机器上只安装了 Toad,给你截图看下

    coolicer
        6
    coolicer  
    OP
       Jun 10, 2015
    @ayumilove 能给个邮箱吗,想问一下你。
    DECLARE
    p1 VARCHAR2(100);
    p2 sys_refcursor;
    p3 VARCHAR2(100);
    BEGIN
    p1:='dd';
    p3:='3';
    testproc(p1,p2,p3);
    -- 这里写法有没有错?然后我再从网上找了循环游标的,但是还是报错。
    END;
    ayumilove
        7
    ayumilove  
       Jun 10, 2015
    SQL> var rset refcursor;
    SQL> exec 存储过程名称(10,:rset);
    SQL> print rset;

    ayumilove # 139.com
    coolicer
        8
    coolicer  
    OP
       Jun 10, 2015
    @ayumilove 谢谢。暂时不管,我们前端写存储过程,丢给后端可以执行。我只是想在软件中执行
    ayumilove
        9
    ayumilove  
       Jun 11, 2015
    我个人
    在用有返回值的 这种情况,一般使用函数;
    DML时候 用存储过程。

    但这不是绝对的,怎么方便怎么来。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2575 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 478ms · UTC 16:08 · PVG 00:08 · LAX 09:08 · JFK 12:08
    ♥ Do have faith in what you're doing.