Maison >base de données >tutoriel mysql >Comment afficher les relations un-à-plusieurs sous forme de listes séparées par des virgules dans Informix SQL ?
Relation un-à-plusieurs sous forme de lignes uniques avec des listes séparées par des virgules à l'aide d'Informix SQL
Semblable aux questions posées sur Stack Overflow, ceci L'article fournit une solution Informix SQL pour afficher une relation un-à-plusieurs sous la forme d'une seule ligne unique séparée par des virgules. listes.
Données initiales
id codes 63592 PELL 58640 SUBL 58640 USBL 73571 PELL 73571 USBL 73571 SUBL
Sortie souhaitée
id codes 63592 PELL 58640 SUBL, USBL 73571 PELL, USBL, SUBL
Agrégat personnalisé défini par l'utilisateur
Pour obtenir le résultat souhaité, un agrégat personnalisé défini par l'utilisateur (UDA) est requis. Vous trouverez ci-dessous un exemple d'UDA nommé group_concat :
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);
Requête avec concaténation groupée
En appliquant l'UDA group_concat aux données d'origine, nous pouvons regrouper par l'identifiant unique et agréger les codes à l'aide du personnalisé UDA :
SELECT id, group_concat(codes) FROM anonymous_table GROUP BY id;
Sortie
58640 SUBL,USBL 63592 PELL 73571 PELL,SUBL,USBL
Notes supplémentaires
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;
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!