WM_CONCAT字符超过4000的处理办法
2012-11-13 22:23
253 查看
参考网址:
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
http://www.williamrobertson.net/documents/one-row.html
在进行使用WM_CONCAT或者自定义的聚合函数,进行拼串的时候,可能遇到拼串形成的结果集大于4000,这时候,系统会提示,超过系统限制。所以,在这个时候,最好的处理办法就是将结果集处理成CLOB格式,
下面共有两种处理方式:
1、使用函数
类型:
函数:
测试:
初始化数据:
测试的SQL语句:
注意:
如下的SQL语句错误:由于类型不同
会抛出如下的异常信息:
因为在str2tbltype中声明的是varchar2,但是现在deptno是数字,所以数据类型会发生不一致,所以,可以使用to_char见其进行转换,来避免上述的错误:
二:使用Oracle的SQL提供的处理XML的语句:XMLAGG()
SQL语句如下:
结果:
具体:
或者使用如下的语句,可以实现同样的功能:
参考网站:http://www.williamrobertson.net/documents/one-row.html
下面的语句,没有调用getClobVal(),聚合的结果集是字符串
关于Oracle中XML的知识,请参考:http://www.oratechinfo.co.uk/sqlxml.html
或者/article/6504505.html
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
http://www.williamrobertson.net/documents/one-row.html
在进行使用WM_CONCAT或者自定义的聚合函数,进行拼串的时候,可能遇到拼串形成的结果集大于4000,这时候,系统会提示,超过系统限制。所以,在这个时候,最好的处理办法就是将结果集处理成CLOB格式,
下面共有两种处理方式:
1、使用函数
类型:
create or replace type str2tblType as table of varchar2(4000)
函数:
CREATE OR REPLACE FUNCTION tab2clob(p_str2tbltype str2tbltype, p_delim IN VARCHAR2 DEFAULT ',') RETURN CLOB IS l_result CLOB; BEGIN FOR cc IN (SELECT column_value FROM TABLE(p_str2tbltype) ORDER BY column_value) LOOP l_result := l_result || p_delim || cc.column_value; END LOOP; RETURN ltrim(l_result, p_delim); END;
测试:
初始化数据:
BEGIN FOR idx IN 1 .. 10000 LOOP INSERT INTO ts1 (tm) VALUES (sys_guid()); END LOOP; END;
测试的SQL语句:
SELECT tab2clob(CAST(COLLECT(tm) AS str2tbltype)) attributes FROM ts1 WHERE rownum < 1000
注意:
如下的SQL语句错误:由于类型不同
SELECT sys_util.tab2clob(CAST(COLLECT(deptno) AS str2tbltype)) FROM (SELECT DISTINCT deptno FROM emp)
会抛出如下的异常信息:
因为在str2tbltype中声明的是varchar2,但是现在deptno是数字,所以数据类型会发生不一致,所以,可以使用to_char见其进行转换,来避免上述的错误:
SELECT sys_util.tab2clob(CAST(COLLECT(to_char(deptno)) AS str2tbltype)) FROM (SELECT DISTINCT deptno FROM emp)
二:使用Oracle的SQL提供的处理XML的语句:XMLAGG()
SQL语句如下:
SELECT rtrim(xmlagg(xmlparse(content ename || ',' wellformed) ORDER BY ename) .getclobval(), ',') attributes, deptno FROM emp GROUP BY deptno;
结果:
具体:
或者使用如下的语句,可以实现同样的功能:
参考网站:http://www.williamrobertson.net/documents/one-row.html
SELECT deptno, trim(xmlagg(xmlelement(content, ename || ',' ) ORDER BY ename) .extract('//text()').getclobval()) AS concatenated FROM emp GROUP BY deptno;
下面的语句,没有调用getClobVal(),聚合的结果集是字符串
SELECT deptno, trim(xmlagg(xmlelement(content, ename || ',' ) ORDER BY ename) .extract('//text()')) AS concatenated FROM emp GROUP BY deptno;
关于Oracle中XML的知识,请参考:http://www.oratechinfo.co.uk/sqlxml.html
或者/article/6504505.html
相关文章推荐
- WM_CONCAT字符超过4000的处理办法
- WM_CONCAT字符超过4000的处理办法
- WM_CONCAT字符超过4000的处理办法
- oracle的函数wm_concat字符超过4000的处理办法
- WM_CONCAT字符超过4000的处理办法
- 自定义聚集函数,仿wm_concat,使用CLOB,可处理超过4000长度字符串
- WMSYS.WM_CONCAT 突破4000字符的方法
- 关于wmsys.wm_concat列超出4000处理
- wm_concat(列名)拼接超过4000后异常
- 数据库存储字符超过2000处理办法;
- 如何处理CLOB字段值超过4000字节时提示:“ORA-01704:文字字符串过长”的错误
- windows mobile WM 6.1MMS subject不超过40个字符添加方法
- C++fstream文件流处理对中文字符不支持的解决办法
- 针对AndroidStudio打包和运行程序是,方法数超过65536的处理办法
- boost使用property_tree/json_parser处理包含中文字符的UTF8时异常的解决办法
- 无法显示XML页--名称以无效字符开头。iis处理资源时出错的解决办法
- Outlook容量超过2G的处理办法
- 动态sql语句超过8000个字符的处理方法
- C++fstream文件流处理对中文字符不支持的解决办法
- wm_concat(column)结果为<clob>的解决办法