破解Oracle函数"wmsys.wm_concat()"
来源:互联网 发布:linux crontab java 编辑:程序博客网 时间:2024/05/17 08:31
自定义此函数是由于“wmsys.wm_concat”在10G中不稳定。现已写成自己定义的函数,功能与用法和“wmsys.wm_concat”函数一样。赶紧贴出了给大伙看看。
备注: 这是从开源网转载而来的源码,经过本人的多次验证和实际运用此函数可行。
create or replace TYPE zh_concat_im AUTHID CURRENT_USER AS OBJECT( CURR_STR VARCHAR2(32767), 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 VARCHAR2, 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_imIS 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 VARCHAR2, 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 VARCHAR2 AGGREGATE USING zh_concat_im ;
用法:
SELECT zh_concat(str) from dual; ---调用函数
备注:以上红色字体可以自定义合并的区分符号。
- 破解Oracle函数"wmsys.wm_concat()"
- oracle wmsys.wm_concat函数
- oracle 内部函数 wmsys.wm_concat
- oracle中的wmsys.wm_concat()函数
- oracle 的wmsys.wm_concat函数用法
- oracle 的wmsys.wm_concat函数用法
- oracle内置函数 wmsys.wm_concat使用
- Oracle函数wmsys.wm_concat的使用
- Oracle函数wmsys.wm_concat的使用
- oracle wmsys.wm_concat(column)函数的使用
- oracle wmsys.wm_concat 函数的使用
- Oracle函数wmsys.wm_concat的使用
- ORACLE的WMSYS.WM_CONCAT聚合函数
- Oracle行转列函数WMSYS.WM_CONCAT() 和 Listagg()
- oracle 替换wmsys.wm_concat的函数
- oracle函数wmsys.wm_concat--有道笔记整理
- Oracle 函数 wmsys.wm_concat 的几个用法
- 关于ORACLE wmsys.wm_concat 行转列函数使用
- PostgreSQL数据库开源连接池pgbouncer的使用
- recovery 英文介绍
- jquery学习笔记
- js学习笔记
- PB 各种小功能点(一)
- 破解Oracle函数"wmsys.wm_concat()"
- Using PGSNAP to Monitor PostgreSQL Database
- php 操作 MySQL 中的Blob类型 存储图片
- binux
- PostgreSQL PARSE等待一例
- 算法学习视频下载
- Swap Consumed very Much When PostgreSQL autovacuum to prevent wraparound
- 自己动手写RTP服务器——传输所有格式的视频
- android不同屏幕大小支持