V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
coolicer
V2EX  ›  程序员

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

  •  
  •   coolicer · 2015-06-09 14:43:29 +08:00 · 2699 次点击
    这是一个创建于 3455 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在网上查到了这样的

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

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

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

    但这不是绝对的,怎么方便怎么来。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1094 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 23:29 · PVG 07:29 · LAX 15:29 · JFK 18:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.