首页 >数据库 >mysql教程 >如何在 Informix SQL 中将一对多关系显示为逗号分隔列表?

如何在 Informix SQL 中将一对多关系显示为逗号分隔列表?

Patricia Arquette
Patricia Arquette原创
2025-01-03 17:29:40304浏览

How to Display One-to-Many Relationships as Comma-Separated Lists in Informix SQL?

使用 Informix SQL 作为具有逗号分隔列表的唯一行的一对多关系

与 Stack Overflow 上提出的问题类似,这本文提供了一个 Informix SQL 解决方案,用于将一对多关系显示为以逗号分隔的单个唯一行

初始数据

id     codes
63592  PELL
58640  SUBL
58640  USBL
73571  PELL
73571  USBL
73571  SUBL

所需输出

id     codes
63592  PELL
58640  SUBL, USBL
73571  PELL, USBL, SUBL

自定义用户定义的聚合

为了实现如果需要输出,则需要自定义用户定义聚合 (UDA)。下面是一个名为 group_concat 的 UDA 示例:

CREATE FUNCTION gc_init(dummy VARCHAR(255)) RETURNING LVARCHAR;
    RETURN '';
END FUNCTION;

CREATE FUNCTION gc_iter(result LVARCHAR, value VARCHAR(255))
    RETURNING LVARCHAR;
    IF result = '' THEN
        RETURN TRIM(value);
    ELSE
        RETURN result || ',' || TRIM(value);
    END IF;
END FUNCTION;

CREATE FUNCTION gc_comb(partial1 LVARCHAR, partial2 LVARCHAR)
    RETURNING LVARCHAR;
    IF partial1 IS NULL OR partial1 = '' THEN
        RETURN partial2;
    ELIF partial2 IS NULL OR partial2 = '' THEN
        RETURN partial1;
    ELSE
        RETURN partial1 || ',' || partial2;
    END IF;
END FUNCTION;

CREATE FUNCTION gc_fini(final LVARCHAR) RETURNING LVARCHAR;
    RETURN final;
END FUNCTION;

CREATE AGGREGATE group_concat
    WITH (INIT = gc_init, ITER = gc_iter,
          COMBINE = gc_comb, FINAL = gc_fini);

分组串联查询

将 group_concat UDA 应用于原始数据,我们可以按唯一 id 进行分组,使用自定义聚合代码UDA:

SELECT id, group_concat(codes)
    FROM anonymous_table
    GROUP BY id;

输出

58640 SUBL,USBL
63592 PELL
73571 PELL,SUBL,USBL

附加注释

  • 此 UDA 处理以下数据类型:可以转换为 VARCHAR(255)(例如,数字或时间
  • 从 Informix 12.10.FC5 开始,聚合结果的最大长度为 16380 字节。
  • 要删除 UDA 和关联函数,请执行以下命令:
DROP AGGREGATE IF EXISTS group_concat;
DROP FUNCTION IF EXISTS gc_fini;
DROP FUNCTION IF EXISTS gc_init;
DROP FUNCTION IF EXISTS gc_iter;
DROP FUNCTION IF EXISTS gc_comb;

以上是如何在 Informix SQL 中将一对多关系显示为逗号分隔列表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn