数据库迁移升级后vm_concat函数引发应用系统异常

晚上对一个小系统做数据迁,很简单,所以就省略了测试的步骤。但是,它却给俺了一个惊喜,前端应用好多报表业务都失效了。

我第一反应是数据没有过来或者损坏了?有了想法就验证,发现表中的数据都是正常的。

那问题就应该在SQL语句上,通过与开发商确认得知,他们使用了vm_concat这个undocumentd的函数!!

好吧,问题的原因基本找到了:
数据迁移是11.2.0.1 --&gt 11.2.0.4
WMSYS用户用于Workspace Manager,其函数对象可能因版本而不同,这种变化在11.2.0.3及10.2.0.5中体现出来。
原本WM_CONCAT函数返回值为VARCHAR2变更为CLOB。这一变化导致了很多程序的异常。

数据已经迁移到目标库,所以只能想个变通的方法来解决这个问题:
将11.2.0.1中的vm_concat函数源码拿过来,在目标库的业务用户下创建
CREATE OR REPLACE type WM_CONCAT_IMPL wrapped
a000000
1
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
d
270 160
bg9hz+fBwa888VEZGViHFs/oOP0wg433f64df3QCWE7VehmhTFcUe3y+JrsniV3cSuvmnE3g
Y93dtR+cCsU1N+UQDGbtzhCf2HIdr8lPzfgF2bmCTvmGlHQbTAjTftNrDq3p093ncwb32OyX
3ZFDTeH2jpjm3uWYyT8kZBfJIYxRwgLfRApoW32cpy0eRnvDBt2XfTAMXKCSNnqSoTiGA83W
6deKW+rWyBu9L/EPyFkmQZeBncNsiNDF8fa1Sm6vdQiEanlCQnaPJ11a0na8hK6psDSaey+x
fdMupCwSvg6gMrSV4QCguhOCqW2AmxRVMqpXJootPpTBxBFZc7hORGbriUI=
/

CREATE OR REPLACE function wm_concat wrapped
a000000
1
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
abcd
8
58 96
+CuW1MAfZPVR6NOnXKVmXY2o9pswg8eZgcfLCNL+XhZy8K7/cgzcVrPnfMPnx3TAM7h0ZSXD
j57Asr2ym9ZtFldFmFu+RdpAU8VGORKSvtVG+DmAOR4C+NTa+Pit2kDbEpI5zhZUgqameSkE
DQ==
/

注意:在11.2.0.3中可以使用listagg来代替vm_concat,这是Oracle推荐的方式。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29843794/viewspace-1328247/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29843794/viewspace-1328247/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值