南大通用GBase 8a之聚合函数: 计算峰度功能的实现

3 阅读1分钟

原文链接:www.gbase.cn/community/p…
更多精彩内容尽在南大通用GBase技术社区,南大通用致力于成为用户最信赖的数据库产品供应商。

主要解决问题

(1)  目前系统缺少求峰度的功能。特编写可以实现该功能的so以应对。

部署方式

(1) 将文件libkurtosis.so 放在集群对应的GBASEHOME/lib/gbase/plugin GBASE_HOME/lib/gbase/plugin  GCLUSTER_HOME/lib/gbase/plugin  目录下
(2) 库内执行:CREATE AGGREGATE FUNCTION kurtosis  RETURNS REAL  SONAME 'libkurtosis.so';

 

使用方式

直接作为库内聚合函数使用,如:

select a,kurtosis( cast(b as double) ) from zhao group by a;

 

演示样例

gbase> create table zhao(a int, b int );
Query OK, 0 rows affected (Elapsed: 00:00:00.21)

gbase> insert into zhao values (1,1),(1,2),(1,3),(1,99),(1,8),(1,7),(1,6);
Query OK, 7 rows affected (Elapsed: 00:00:00.15)
Records: 7  Duplicates: 0  Warnings: 0

gbase> insert into zhao values (2,1),(2,2),(2,3),(2,9),(2,4),(2,3),(2,2);
Query OK, 7 rows affected (Elapsed: 00:00:00.12)
Records: 7  Duplicates: 0  Warnings: 0


gbase> select a,kurtosis( cast(b as double) ) from zhao group by a;
+------+-------------------------------+
| a    | kurtosis( cast(b as double) ) |
+------+-------------------------------+
|    1 |                      2.116505 |
|    2 |                      1.050244 |
+------+-------------------------------+
2 rows in set (Elapsed: 00:00:00.23)

可见,函数可有效区分组1数据比组2数据异常。

 

  1. 参考文件

(1) 注: 该版本为centos7环境下编译。

(2) 文件下载:libkurtosis.so

通过网盘分享的文件:libkurtosis.so
链接: pan.baidu.com/s/1GMCxZejR… 提取码: uuux

原文链接:www.gbase.cn/community/p…
更多精彩内容尽在南大通用GBase技术社区,南大通用致力于成为用户最信赖的数据库产品供应商。