PL/SQL - 动态访问光标数据

Posted

技术标签:

【中文标题】PL/SQL - 动态访问光标数据【英文标题】:PL/SQL - Access the Cursor Data Dynamically 【发布时间】:2018-01-16 15:12:54 【问题描述】:

我使用了两个游标 1) c_emp 游标有表数据。 2) c_column_names 游标具有表中的列。 我想动态地使用 c_column_names 游标从 c_emp 游标中获取所有列的数据。

我尝试使用以下代码,但它不起作用:

create or replace procedure sp_read_data(in_tb_nm varchar2) as
cursor c_emp is select * from test_table;
begin    
    open c_column_names for select column_name from all_tab_columns where table_name = 'TEST_TABLE';      
    for emp_row in c_emp
    loop    
      loop
          fetch c_column_names into lc_record;
          exit when c_column_names %notfound;                
          lc_col_nm := 'emp_row.'||lc_record;
          v_dtl := v_dtl || rpad (lc_col_nm, 20, ' ');
      end loop;     
    end loop;      
end sp_read_data;

有没有办法动态访问游标数据?

【问题讨论】:

不清楚您要达到的目标。参数in_tb_nm的用途是什么?你在哪里声明lc_record?也许向我们展示静态 SQL 的样子。 这里需要 2 个循环吗?另外,让我们知道您的最终预期结果是什么。可能有更简单的方法来实现它 【参考方案1】:

认为你有点在重新发明***。为什么不使用 REF CURSOR?

SQL> create or replace function sp_read_data (in_tb_nm in varchar2)
  2    return sys_refcursor
  3  is
  4    cur_r sys_refcursor;
  5  begin
  6    open cur_r for 'select * from ' || in_tb_nm;
  7    return cur_r;
  8  end;
  9  /

Function created.

SQL> select sp_read_data('departments') from dual;
CURSOR STATEMENT : 1

CURSOR STATEMENT : 1
           10 Administration                        200        1700
           20 Marketing                             201        1800
           30 Purchasing                            114        1700
           40 Human Resources                       203        2400
           50 Shipping                              121        1500
           60 IT                                    103        1400
           <snip>

【讨论】:

以上是关于PL/SQL - 动态访问光标数据的主要内容,如果未能解决你的问题,请参考以下文章

打印 Oracle Pl/sql 光标

PL/SQL开发中动态SQL的使用方法

PL/SQL Developer动态执行表不可访问,本会话的自动统计被禁止

PL/SQL-如何使用游标的所有列插入表

PL/SQL UTL_HTTP 发送多个原始数据

PL/SQL, DBMS_SQL 无法显示数据