oracle 自定义聚合函数(按字段分组,非分组字段进行合并)
按字段进行分组,没分组字段通过函数进行字符串的合并,用','分割
CREATE OR REPLACE FUNCTION zh_concat(P1 VARCHAR2) RETURN clob AGGREGATE USING zh_concat_im;
-----------------------------------------------------------------------------------------------
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 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
)
- oracle 按字段分组,非分组字段进行合并(可根据字段排序)
- oracle:自定义多行合并聚合函数
- 当字段内有逗号分隔时,Oracle如何对这些字段值进行分组
- oracle分组后合并其中一个字段
- oracle 按某个字段分组然后从每组取出最大的一条纪录
- 关于分组后字段拼接的问题 (Oracle)
- 当字段内有逗号分隔时,SQL如何对这些字段值进行分组
- MySQL语句进行分组后的含有字段拼接方法
- oracle分页查询并按照某字段进行排序的数种解决方案
- oracle的聚集函数wm_concat()和listagg()不适用时,自定义通用的聚集函数合并查询结果列
- Oracle 如何对中文字段进行排序
- oracle通过一个字段分组,并将另一字段拼接
- 如何对CLOB字段进行全文检索和oracle中大文字量的处理
- 使用case when高级用法对数据库进行行列转化 分组、聚合函数使用
- ORACLE分析函数(7)----自定义聚合函数
- 将List中的实体按照某个字段进行分组的算法
- ORACLE 连接某个字段及分组后取某个字段最大(最小)等实现方法
- MYSQL GROUP BY 对多个字段进行分组
- ORACLE里的CLOB字段进行模糊查询
- oracle,分组后,字符串以“,”合并