首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >PL/SQL中的动态循环

PL/SQL中的动态循环
EN

Stack Overflow用户
提问于 2019-01-31 08:50:18
回答 1查看 100关注 0票数 0

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

代码语言:javascript
运行
复制
for c in (select * from example_table where name is not null) loop  
  -- logic  
end loop; 

我想用动态SQL语句替换SQL语句,例如:

代码语言:javascript
运行
复制
l_sql := 'select * from example_table where || l_col || is not null';  
for c in (l_sql) loop  
  -- logic  
end loop;  

这个是可能的吗?

诚挚的问候

EN

Stack Overflow用户

发布于 2019-01-31 11:27:16

对于隐式游标循环( for loop中的select ),这是不可能的。您可以通过记录变量为tablename%ROWTYPEREFCURSOR使用传统的OPEN .. FETCH .. LOOP

代码语言:javascript
运行
复制
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;
/
票数 2
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54451824

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档