使用 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
附加注释
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中文网其他相关文章!