技术阿道 2019-08-22 16:12 采纳率: 22.2%
浏览 737
已结题

plsql中的存储过程execute immediate相关问题

图片说明
create or replace procedure SP_GRN_PROCESS
(kssj in date,
jssj in date,
typename in varchar2,
result_process out sys_refcursor
) is
v_sql varchar2(2000);
begin

v_sql :='select a.doc_subject,
       a.fd_number,
       b.fd_fact_node_name,
       to_char(b.fd_start_date,''yyyy-mm-dd hh24:mi:ss'') as fd_start_date,
       to_char(b.fd_finish_date,''yyyy-mm-dd hh24:mi:ss'') as fd_finish_date,
       b.fd_target_name
from km_review_main  a,lbpm_history_node  b,km_review_template  c
where a.fd_id = b.fd_process_id 
and a.fd_template_id = c.fd_id
and (to_char(b.fd_start_date,''yyyy-mm-dd'') = to_char( '''||kssj||''',''yyyy-mm-dd'') or '''||kssj||''' is null) 
and (to_char(b.fd_finish_date,''yyyy-mm-dd'') = to_char( '''||jssj||''',''yyyy-mm-dd'') or '''||jssj||''' is null) 
and'|| (' (c.fd_name LIKE ''%' || replace(typename,',','%'' OR c.fd_name LIKE ''%')  ||  '%'')')||
' order by a.doc_subject,fd_start_date asc';

open result_process for  execute immediate v_sql;

end SP_GRN_PROCESS;
这个 execute immediate v_sql执行的是没有问题,我debug有看了一下v_sql中的值,并拿出来执行,没问题。但我想要这个存储过程的结果集,所以加了游标,现在不知道要怎么把execute immediate v_sql放到游标里,或者有什么方法可以看到execute immediate v_sql执行后的结果集?求大神帮忙

  • 写回答

2条回答 默认 最新

  • wilson1966 2019-08-23 09:36
    关注

    可参考一下我的范例
    先建立PROCEDURE XXb

    CREATE OR REPLACE PROCEDURE XXb( p_rc OUT SYS_REFCURSOR )
    AS
    BEGIN
      OPEN p_rc 
       FOR select id,eq from xx2
    where wpsid = 'PR12100';
    END;
    

    前台 call

    DECLARE
      l_cursor SYS_REFCURSOR;
      l_id  varchar(100);
      l_seq varchar(100);
    begin
      XXb( l_cursor );
    LOOP 
        FETCH l_cursor
        INTO  l_id, l_seq;
        EXIT WHEN l_cursor%NOTFOUND;
        DBMS_OUTPUT.PUT_LINE(l_id || ' | ' || l_seq );
      END LOOP;
      CLOSE l_cursor;
    end;
    /
    

    在我的计算机测试OK
    你试一下

    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码