ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 从oracle 行列转化函数 想到的

从oracle 行列转化函数 想到的

原创 Linux操作系统 作者:kinglin_zy 时间:2011-06-29 01:08:43 0 删除 编辑

Oracle 10g 以后可以用 wmsys.wm_concat 函数实现行列转换。

如果提示找不到,则需要run下面的脚本建相关的对象:

For Install
$ORACLE_HOME/rdbms/admin/owminst.plb
For uninstall
$ORACLE_HOME/rdbms/admin/owmuinst.plb

至于具体用法,在oracle base 上找到一篇挺不错的文章,举一反三的:

http://www.oracle-base.com/articles/misc/StringAggregationTechniques.php

但是,这个函数的输出是有长度限制的。而且在oracle的官方文档上找不到对wmsys.wm_concat的介绍,应该又是一个 no doc 函数了。这个函数是加密的,但是网上找了实现相同功能的自定义函数,并通过改写成将输出变为了LOB.

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 ;

这里频繁用到了 User-Defined Aggregate Functions Interface。

比如:ODCIAggregateMerge()

而这也是上家公司的老工程师最爱用的。这个在oracle官网是有详细介绍的:

http://download.oracle.com/docs/cd/B19306_01/appdev.102/b14289/dciaggref.htm#sthref1104

zh_concat_im没法自定义delimeter,继续改写如下:


 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/781883/viewspace-700927/,如需转载,请注明出处,否则将追究法律责任。

下一篇: trap 简介
请登录后发表评论 登录
全部评论

注册时间:2009-09-22

  • 博文量
    58
  • 访问量
    67160