在进行使用WM_CONCAT 进行列转行的字符串拼接时,可能会遇到长度超过4000的情况。这个时候oracle会报错。所以,在这个时候,最好的处理办法就是将结果集处理成CLOB格式。
下面是自定义的行转列函数。
CREATE OR REPLACE TYPE zh_concat_im
AUTHID CURRENT_USER AS OBJECT
(
CURR_STR clob,
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT zh_concat_im) RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT zh_concat_im,
P1 IN VARCHAR2) RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN zh_concat_im,
RETURNVALUE OUT clob,
FLAGS IN NUMBER)
RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT zh_concat_im,
SCTX2 IN zh_concat_im) RETURN NUMBER
);
CREATE OR REPLACE TYPE BODY zh_concat_im
IS
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT zh_concat_im)
RETURN NUMBER
IS
BEGIN
SCTX := zh_concat_im(NULL) ;
RETURN ODCICONST.SUCCESS;
END;
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT zh_concat_im,
P1 IN VARCHAR2)
RETURN NUMBER
IS
BEGIN
IF(CURR_STR IS NOT NULL) THEN
CURR_STR := CURR_STR || ’,’ || P1;
ELSE
CURR_STR := P1;
END IF;
RETURN ODCICONST.SUCCESS;
END;
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN zh_concat_im,
RETURNVALUE OUT clob,
FLAGS IN NUMBER)
RETURN NUMBER
IS
BEGIN
RETURNVALUE := CURR_STR ;
RETURN ODCICONST.SUCCESS;
END;
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT zh_concat_im,
SCTX2 IN zh_concat_im)
RETURN NUMBER
IS
BEGIN
IF(SCTX2.CURR_STR IS NOT NULL) THEN
SELF.CURR_STR := SELF.CURR_STR || ’,’ || SCTX2.CURR_STR ;
END IF;
RETURN ODCICONST.SUCCESS;
END;
END;
create or replace FUNCTION zh_concat(P1 VARCHAR2)
RETURN clob AGGREGATE USING zh_concat_im ;
然后用自定义的ZH_CONCAT替换掉系统当中WM_CONCAT超长报错的地方,系统中直接将结果集映射成String型即可解决问题。
————————————————
原文链接:https://blog.csdn.net/huyekeke1989/article/details/83504369
场景:使用select
wm
_
concat
(xxxxx) from table 的时候 返回的字符串过长
解决方案 :使用to_clob 将字符串转成 clob类型,但是由于使用的前端框架不能解析clob类型的值
再将clob转化成String类型
List<Map> olists=oDao.queryOrgRoleInfo(qu...
在进行使用
WM
_
CONCAT
进行列转行的字符串拼接时,可能会遇到
长度
超过4000的情况。这个时候
oracle
会报错。所以,在这个时候,最好的处理办法就是将结果集处理成CLOB格式。
下面是自定义的行转列函数。
CREATE OR REPLACE TYPE zh_
concat
_im
AUTHID CURRENT_USER AS OBJECT
CURR_STR clob,
STATIC FUNC...
参考网址:
http://stackoverflow.com/questions/11541383/ordering-by-list-of-strings-in-
oracle
-
sql
-without-listagg
字符串拼接技巧和方式:http://www.
oracle
-base.com/articles/misc/string-aggregation-techniques.php
在我的BLOG中第一篇文章写的就是字符串聚合连接的例子:http://yangtingkun.itpub.net/post/468/3380。
后来还写过一篇用
SQL
实现相同功能的文章:http://yangtingkun.itpub.net/post/468/388003。
不过上面两种方法都会面临一个
问题
,就是如果聚集连接的字符串
长度
如果超过了VAR
CHAR
2类型所允许的最大
长度
,就会导致
java
.
sql
.
SQL
Exception: ORA-06502: PL/
SQL
: 数字或值错误 : 字符串缓冲区太小 ORA-06512: 在 "
WM
SYS.
WM
_
CONCAT
_IMPL", line 30 )
wm
_
concat
的最大
长度
只有4000,超过就会报错,
Oracle
自定义
wm
sys.
wm
_
concat
避免
长度
限制 网上搜索到这段类似代码但是
长度
过程还是不行,经过我的修改,亲测可以。
CREATE OR REPLACE TYPE ZH_
CONCAT
_IM
AUTHID CURRENT_USER AS OBJECT
CURR_STR CLOB,
STATIC FUNCTION ODCIAGGREGATEINITIALIZ
Invalid tld file: "/WEB-INF/tags/xxxt.tld", see JSP 2.2 specification section 7.3.1 for more details