繁体   English   中英

PL / SQL中的动态循环

[英]Dynamic loop in PL/SQL

我目前正在使用以下内容遍历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;  

这可能吗?

最好的祝福

这对于隐式游标循环是不可能的( for loop选择内部)。 您可以通过带有tablename%ROWTYPE的记录变量的REFCURSOR使用常规的OPEN .. FETCH .. LOOP

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;
/

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM