Oracle PLSQL TABLE类型的TO_CHAR

Oracle PLSQL TABLE类型的TO_CHAR,第1张

概述出于调试目的,我希望能够“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, 出于调试目的,我希望能够“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) ISbegin    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 ……)

希望有所帮助

总结

以上是内存溢出为你收集整理的Oracle PL / SQL TABLE类型的TO_CHAR全部内容,希望文章能够帮你解决Oracle PL / SQL TABLE类型的TO_CHAR所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1165198.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存