WMSYS.WM_CONCAT 过长问题的解决
来源:互联网 发布:手机侦探软件 编辑:程序博客网 时间:2024/05/17 09:44
在项目中,出现了使用WMSYS.WM_CONCAT合并列内容,导致内容过长出现异常。
select bill_id, WMSYS.WM_CONCAT(message) as message from tblbill_msg group by bill_id
网上查了资料,使用自定义类型方式进行处理。
----------创建自定义类型
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 ;
完整创建后,进行调用处理:
select bill_id, (case when count(message) <> 1 then '内容过长发送请查看<短信记录>'
else to_char(zh_concat(message)) end) as message
from tblbill_msg group by bill_id
- WMSYS.WM_CONCAT 过长问题的解决
- 字符串连接超长的解决wmsys.wm_concat()
- wmsys.wm_concat结果长度限制的问题
- wmsys.wm_concat结果长度限制的问题
- wmsys.wm_concat 长度限制的问题
- wmsys.wm_concat的用法
- oracle XE解决WMSYS.WM_CONCAT()不可用的情况
- ORACLE 函数处理的数据返回值过长 character string buffer too small , WMSYS.WM_CONCAT
- wmsys.wm_concat的几个用法
- wmsys.wm_concat的几个用法
- wmsys.wm_concat的几个用法
- WMSYS.WM_CONCAT 函数的用法
- wmsys.wm_concat的几个用法
- wmsys.wm_concat的几个用法
- wmsys.wm_concat的几个用法 .
- wmsys.wm_concat的几个用法
- wmsys.wm_concat的几个用法
- wmsys.wm_concat( ) 常用的使用方法
- android aidl
- 学生信息管理系统总结 之 "数据库"
- [MSSQL]T-SQL自定义函数LeftPad
- 工厂模式
- hashmap treemap
- WMSYS.WM_CONCAT 过长问题的解决
- grep 命令
- Linux如何在系统启动时自动加载模块
- 数据库三范式,轻松理解
- 英文信件格式
- 二叉树----节点个数、高度、递归和非递归遍历、按层遍历
- 7.EL入门:forTokens
- SEO人生衔接后用户可随时随地同他的合作伙伴协同工作
- 嵌入式linux启动过程详解