晚上对一个小系统做数据迁,很简单,所以就省略了测试的步骤。但是,它却给俺了一个惊喜,前端应用好多报表业务都失效了。
我第一反应是数据没有过来或者损坏了?有了想法就验证,发现表中的数据都是正常的。
那问题就应该在SQL语句上,通过与开发商确认得知,他们使用了vm_concat这个undocumentd的函数!!
好吧,问题的原因基本找到了:
数据迁移是11.2.0.1 --> 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/