使用立即执行引用游标

Nav*_*thy 2 sql oracle plsql sys-refcursor execute-immediate

我想在ref_cursor中得到结果,但我无法做到这一点.

请建议我如何使用Execute immediate在ref_cursor中获取结果

CREATE OR REPLACE PROCEDURE TEST_PROC_QT ( p_name IN VARCHAR2,
                                           p_result_set OUT sys_refcursor ) IS

  v_sql VARCHAR2(4000);

BEGIN

   v_sql := '';
   v_sql := 'SELECT * FROM USERS WHERE 1=1 ';

   IF p_name is not null THEN
     v_sql := v_sql || ' AND login_id = :v_name';
   ELSE
     v_sql := v_sql || ' AND ((1=1) or :v_name is null)';
   END IF;

   Dbms_output.put_line(v_sql);

   EXECUTE IMMEDIATE v_sql

   --OPEN p_result_set for v_sql
   --INTO p_result_set using p_name;  

END;
Run Code Online (Sandbox Code Playgroud)

Ton*_*ews 9

只是:

OPEN p_result_set for v_sql using p_name;  
Run Code Online (Sandbox Code Playgroud)