GBase 8a 函数参数形式及结构

本文详细介绍了GBase 8a中创建用户定义函数(UDF)时,函数参数的形式和结构。包括针对不同返回类型(STRING、INTEGER、REAL)的主函数形式,以及初始化和结束函数的声明。同时,解析了UDF_INIT结构中的参数如maybe_null、decimals、max_length等,以及UDF_ARGS结构中arg_count、arg_type、args、lengths、maybe_null和attributes等成员的作用。
摘要由CSDN通过智能技术生成

1、 函数参数形式
1 主函数返回类型和参数的不同取决于CREATE FUNCTION语句中声明SQL函数func()返回类型

对SQL中返回STRING的函数,形式如下:

char *func(UDF_INIT *initid, UDF_ARGS *args,

                 char *result, unsigned long *length,

                            char *is_null, char *error);

对SQL中返回INTEGER函数,形式如下:

long long func(UDF_INIT *initid, UDF_ARGS *args,

                              char *is_null, char *error);

对SQL中返回REAL函数,形式如下:

double func(UDF_INIT *initid, UDF_ARGS *args,

                              char *is_null, char *error);

2 初始化函数和结束函数的声明形式如下:

my_bool func_init(UDF_INIT *initid, UDF_ARGS *args, char *message);

void func_deinit(UDF_INIT *initid);

2、参数结构
1.2.1 initid参数
这个参数被传给所有3个函数,它指向一个UDF_INIT结构,被用来在函数之间传递信息。UDF_INIT结构成员列在下面。初始化函数应该初始化它想要改变的任何成员。(对一个成员使用缺省值,不改变它

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值