Oracle   发布时间:2022-05-17  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了oracle如何合并多个sys_refcursor详解大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

一、背景

在数据开发中,有时你需要合并两个动态游标sys_refcursor。

开发一个存储过程PROC_A,这个过程业务逻辑相当复杂,代码篇幅较长。一段时间后要开发一个PROC_B,要用PROC_A同样的逻辑,而且在这个过程中,还要循环调用PROC_A这个过程。摆在你面前的有两个选择。

  • 打开pl/sql,仔细的读PROC_A这个过程,一直到明白了所有的逻辑,然后在自己的过程中重写这个逻辑 。
  • 直接复制PROC_A这个过的代码过来,多写极端。还是业界标准大法好
  • 针对循环调用的,建立一个临时表,循环插入数据到临时表(但这里还有一个问题,每次返回的游标可能列都不相同,建立临时表就显得复杂了)

好吧,这个新的过程是完成了,可是看上去,它更复杂了,代码量更大了。完全不能接受,必须改改!
这时,已经默默打开了OracLE官方帮助文档 ,寻找一个可行的办法,最终目标标是要解析,整合,合并 游标 sys_refcursor

二、思路


经过搜索查询,找到以下可行的方案

  1. 序列化sys_refcursor为xml文档,OracLE对xml支持还不错,12C已经有JSON格式了
  2. 使用OracLE xml解析的方法,对序列化的xml文档,添加、删除、修改
  3. 转换为内存表,通过游标返回查询的结果

为此你@R_643_9262@知识有

  • 使用 DBMS_Lob 个package操作clob类型数据,因为解析后的游标可能用varchar2是装不下的,帮助地址 。
  • 重点掌握Oracle类型xmltype如何使用

三、实现


从上边的帮助文档中,知道xmltype的构造函数中可以直接传入游标xmltype(refcursor)从而得到一个xmltype,调用Xmltype的getClobVal方法,可得到序列化的结果,所以它的结构是这样的

<?xml version="1.0" ?="">




<...>...

....

大佬总结

以上是大佬教程为你收集整理的oracle如何合并多个sys_refcursor详解全部内容,希望文章能够帮你解决oracle如何合并多个sys_refcursor详解所遇到的程序开发问题。

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

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: