Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/69.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PL/SQL中的动态循环_Sql_Oracle_Plsql - Fatal编程技术网

PL/SQL中的动态循环

PL/SQL中的动态循环,sql,oracle,plsql,Sql,Oracle,Plsql,我目前正在使用以下内容循环PL/SQL中的值: for c in (select * from example_table where name is not null) loop -- logic end loop; 我想用动态语句替换SQL语句,例如: l_sql := 'select * from example_table where || l_col || is not null'; for c in (l_sql) loop -- logic end

我目前正在使用以下内容循环PL/SQL中的值:

for c in (select * from example_table where name is not null) loop  
  -- logic  
end loop; 
我想用动态语句替换SQL语句,例如:

l_sql := 'select * from example_table where || l_col || is not null';  
for c in (l_sql) loop  
  -- logic  
end loop;  
这可能吗


致以最诚挚的问候

隐式光标循环不可能实现这一点(为循环选择inside
)。您可以使用传统的
OPEN。。取来使用记录变量
tablename%ROWTYPE

DECLARE
t_rec  example_table%ROWTYPE;
l_sql  VARCHAR2(1000);
v_cur SYS_REFCURSOR;
l_col varchar2(32) := 'MY_COLUMN';
BEGIN
  l_sql := 'select * from example_table where '|| l_col || ' is not null';  

OPEN v_cur FOR l_sql;
   LOOP
      FETCH v_cur INTO t_rec; --fetch a row 
         EXIT WHEN v_cur%NOTFOUND;

    -- your logic using t_rec columns.
   END LOOP;
CLOSE v_cur;

END;
/

对于隐式光标循环,这是不可能的(为循环选择inside
)。您可以使用传统的
OPEN。。取来使用记录变量
tablename%ROWTYPE

DECLARE
t_rec  example_table%ROWTYPE;
l_sql  VARCHAR2(1000);
v_cur SYS_REFCURSOR;
l_col varchar2(32) := 'MY_COLUMN';
BEGIN
  l_sql := 'select * from example_table where '|| l_col || ' is not null';  

OPEN v_cur FOR l_sql;
   LOOP
      FETCH v_cur INTO t_rec; --fetch a row 
         EXIT WHEN v_cur%NOTFOUND;

    -- your logic using t_rec columns.
   END LOOP;
CLOSE v_cur;

END;
/

你想要这样的吗?你想要这样的吗?