加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

Oracle PL / SQL TABLE类型的TO_CHAR

发布时间:2021-02-27 02:19:20 所属栏目:站长百科 来源:网络整理
导读:出于调试目标,我但愿可以或许“TO_CHAR”一个Oracle PL / SQL内存表.这是一个简朴的例子,我想做的工作: DECLARE TYPE T IS TABLE OF MY_TABLE%ROWTYPE INDEX BY PLS_INTEGER; V T;BEGIN -- .. -- Here,I'd like to dbms_output V's contents,which of course do

出于调试目标,我但愿可以或许“TO_CHAR”一个Oracle PL / SQL内存表.这是一个简朴的例子,我想做的工作:

DECLARE
  TYPE T IS TABLE OF MY_TABLE%ROWTYPE INDEX BY PLS_INTEGER;
  V T;

BEGIN
  -- ..

  -- Here,I'd like to dbms_output V's contents,which of course doesn't compile
  FOR i IN V.FIRST .. V.LAST LOOP
    dbms_output.put_line(V(i));
  END LOOP;

  -- I want to omit doing this:
  FOR i IN V.FIRST .. V.LAST LOOP
    dbms_output.put_line(V(i).ID || ',' || V(i).AMOUNT ...);
  END LOOP;

END;

简朴来说,这可以实现吗?我问的缘故起因是由于瘟袅得一次又一次地编写这个调试代码,并且我想在任何表范例中行使它.

办理要领

对不起,这不完备,但要跟进@Lukas,这是我到今朝为止所做的:

起首,我没有实行建设任何数据/任何范例,而是实行行使从游标中提取的XML …很稀疏,但它的泛型:

CREATE OR REPLACE procedure printCur(in_cursor IN sys_refcursor) IS
begin

    FOR c IN (SELECT ROWNUM rn,t2.COLUMN_VALUE.getrootelement () NAME,EXTRACTVALUE (t2.COLUMN_VALUE,'node()') VALUE
               FROM TABLE (XMLSEQUENCE (in_cursor)) t,TABLE (XMLSEQUENCE (EXTRACT (COLUMN_VALUE,'/ROW/node()'))) t2
               order by 1)

   LOOP
      DBMS_OUTPUT.put_line (c.NAME || ': ' || c.VALUE);
   END LOOP;

exception
    when others then raise;
end;
/

此刻,要挪用它,你必要一个游标,以是我实行在pl / sql中转换为游标,相同于:

open v_cur for select * from table(cast(v_tab as tab_type));

可是按照v_tab的界说方法,这也许会也也许不会导致pl / sql逼迫转换题目(在嵌套表def中行使%rowtype好像会发生题目).

无论怎样,您可以在此基本上构建或按照必要举办优化. (而且也许行使xmltable ……)

但愿有所辅佐

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读