一个Oracle自定义聚集函数的例子
来源:互联网 发布:展板用什么软件 编辑:程序博客网 时间:2024/04/28 04:34
前天有人提了需求,想对某个字段进行按位的或操作。本来建议查询出来之后在应用程序里面处理,但是数据量比较大,觉得还是返回一个分组计算之后的值比较合适。
两个问题,一个是按为或的操作,这个参考了别人的文档,用bitand函数实现。 原文如下:
http://blog.chinahr.com/blog/hewy0526/post/112968
然后就是自定义的聚集函数了。这个参考了官方文档的例子,就不列出原文出处了。
全部代码如下:
-- 1. Implement the type BitOrImpl to contain the ODCIAggregate routines:
create type BitOrImpl as object
(
bitorval NUMBER, -- result.
static function ODCIAggregateInitialize(sctx IN OUT BitOrImpl)
return number,
member function ODCIAggregateIterate(self IN OUT BitOrImpl,
value IN number) return number,
member function ODCIAggregateTerminate(self IN BitOrImpl,
returnValue OUT number, flags IN number) return number,
member function ODCIAggregateMerge(self IN OUT BitOrImpl,
ctx2 IN BitOrImpl) return number
);
/
-- 2. mplement the type body for BitOrImpl:
create or replace type body BitOrImpl is
static function ODCIAggregateInitialize(sctx IN OUT BitOrImpl)
return number is
begin
sctx := BitOrImpl(0);
return ODCIConst.Success;
end;
member function ODCIAggregateIterate(self IN OUT BitOrImpl, value IN number) return number is
begin
self.bitorval := (self.bitorval + value) - bitand(self.bitorval, value);
return ODCIConst.Success;
end;
member function ODCIAggregateTerminate(self IN BitOrImpl,
returnValue OUT number, flags IN number) return number is
begin
returnValue := self.bitorval;
return ODCIConst.Success;
end;
member function ODCIAggregateMerge(self IN OUT BitOrImpl, ctx2 IN BitOrImpl) return number is
begin
self.bitorval := (self.bitorval + ctx2.bitorval) - bitand(self.bitorval, ctx2.bitorval);
return ODCIConst.Success;
end;
end;
/
-- 3. Create the user-defined aggregate:
CREATE FUNCTION BitOr (input NUMBER) RETURN NUMBER
PARALLEL_ENABLE AGGREGATE USING BitOrImpl;
/
测试通过。
- 一个Oracle自定义聚集函数的例子
- Oracle自定义聚集函数
- Oracle自定义聚集函数
- Oracle自定义聚集函数
- Oracle自定义聚集函数
- oracle自定义聚集函数
- 对字符串的“sum”——在Oracle中自定义聚集函数的例子
- 对字符串的“sum”——在Oracle中自定义聚集函数的例子
- 对字符串的“sum”——在Oracle中自定义聚集函数的例子
- 对字符串的“sum”——在Oracle中自定义聚集函数的例子
- 一个非常有用的自定义聚集函数
- 关于oracle9以上自定义聚集函数的例子
- Oracle中自定义聚集函数
- oracle的聚集函数
- 他山之石,可以攻玉--Oracle自定义的聚集函数的强大功能
- Oracle自定义的聚集函数的强大功能
- Oracle自定义函数的例子
- 自定义oracle聚集函数,类似于功能wm_concat
- windows xp 里让解压版tomcat随系统启动
- AjaxControltoolkit学习笔记—ModalPopup使用详解 (asp.net C#)
- 推定全损
- 这话说的挺好:连禽兽也不会反咬给自己喂食的手
- 旧历11月初九
- 一个Oracle自定义聚集函数的例子
- 计算机常用术语
- Android ADT: Unable to get buffer of resource asset file
- http获取网页内容类
- 编译原理
- Java 学习杂谈
- 向指定txt文件里添加、读取和删除信息实例
- internal 修饰符的作用
- Matlab(mathworks.com) 随机数生成方法