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 ?

Comment afficher les relations un-à-plusieurs sous forme de listes séparées par des virgules dans Informix SQL ?

Patricia Arquette
Patricia Arquetteoriginal
2025-01-03 17:29:40275parcourir

How to Display One-to-Many Relationships as Comma-Separated Lists in 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

  • Cet UDA gère les types de données qui peut être converti en VARCHAR(255) (par exemple, numérique ou temporel types).
  • À partir d'Informix 12.10.FC5, la longueur maximale du résultat agrégé semble être de 16 380 octets.
  • Pour supprimer l'UDA et les fonctions associées, exécutez les commandes suivantes :
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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn