Informix自定义聚集函数

Informix自定义聚集函数

 

如何自定义聚集函数,本文章以 strsum 函数举例.

 

功能说明:

strsum函数的功能:使用 '-'连接符号将多个字符连接在一起。

举例:

create table test_str(t1 integer,t2 varchar(255));

test_str的数据如下

insert into test_str values (1,'A');

insert into test_str values (1,'B');

insert into test_str values (1,'C');

insert into test_str values (2,'A');

insert into test_str values (2,'B');

insert into test_str values (3,'A');

insert into test_str values (4,'A');

 

select t1,strsum(t2) t2_sum from test_str

where 1=1

group by t1 order by t1;

t1 t2_sum

1     A-B-C-

2     A-B-

3     A-

4     A-

 

若需要去掉最后一个'-'字符只需要修改为如下SQL

select t1,rtrim(strsum(t2),'-') t2_sum from test_str

where 1=1

group by t1 order by t1;

t1 t2_sum

1     A-B-C

2     A-B

3     A

4     A

 

在某些情况,我们需要采用不同的连接符,我们只需要修改查询SQL语句,采用replace函数替换'-'符号。

select t1,replace(rtrim(strsum(t2),'-'),'-','||') t2_sum from test_str

where 1=1

group by t1 order by t1;

t1 t2_sum

1     A||B||C

2     A||B

3     A

4     A

 

 

如何定义聚集函数

如下我们将说明如何自定义该聚集函数strsum

首先定义聚集函数的4个子函数str_sum_init,str_sum_iter,str_sum_combine,str_sum_final;其中str_sum_iter中定义了聚集算法为:采用'-'连接。

最后定义聚集函数strsum

 

代码详细见如下:

 

CREATE FUNCTION str_sum_init (dummy lvarchar(4000))

   RETURNING lvarchar(4000);

   RETURN '';

END FUNCTION;

 

CREATE FUNCTION str_sum_iter (result lvarchar(4000), value lvarchar(4000))

   RETURNING lvarchar(4000);

   RETURN result || value ||'-';

END FUNCTION;

 

CREATE FUNCTION str_sum_combine(partial1 lvarchar(4000), partial2 lvarchar(4000))

   RETURNING lvarchar(4000);

   RETURN partial1 || partial2;

END FUNCTION;

 

CREATE FUNCTION str_sum_final(final lvarchar(4000))

   RETURNING lvarchar(4000);

   RETURN final;

END FUNCTION;

 

CREATE AGGREGATE strsum  WITH

   (INIT = str_sum_init,

    ITER = str_sum_iter,

    COMBINE = str_sum_combine,

    FINAL = str_sum_final);

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Informix中,REPLACE是一个用于字符串替换的函数。根据引用中的SQL语句,可以看出在informix.t_nameinfo表中进行了多次替换操作。首先,使用UPDATE语句将字段code中的中文分号替换为星号,并将替换后的结果更新到表中;接着,使用SELECT语句查询更新后的结果。然后,使用UPDATE语句将字段code中的中文冒号替换为减号,并将替换后的结果更新到表中;再次使用SELECT语句查询更新后的结果。接下来,使用UPDATE语句将字段standardname中的中文分号替换为星号,并将替换后的结果更新到表中;再次使用SELECT语句查询更新后的结果。最后,使用UPDATE语句将字段standardname中的中文冒号替换为减号,并将替换后的结果更新到表中;再次使用SELECT语句查询更新后的结果。这些操作可以帮助你在Informix中使用REPLACE函数进行字符串替换。引用 关于Informix replace的更多详细信息可以参考引用中的博客文章。在该文章中,提到了Informix的REPLACE函数用于替换字符串中的指定字符或子字符串。你可以指定要替换的字符串、替换成的字符串以及要替换的字段。通过使用REPLACE函数,可以方便地在Informix中进行字符串替换操作。引用 根据引用中的引用内容,Informix是一种支持多种数据库类型的数据库管理系统。它具有广泛的功能和支持多种协议。因此,可以使用Informix来管理和访问Oracle、Informix、DB2、SQL-Server、Sybase、MySQL等类型的数据库。引用<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Informix 数据库字段replace](https://blog.csdn.net/iteye_2179/article/details/81972489)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Informix SQL函数的详细用法](https://blog.csdn.net/weixin_30254435/article/details/98732931)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [安信通数据库审计系统.doc](https://download.csdn.net/download/qq_43934844/87577690)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值