>데이터 베이스 >MySQL 튜토리얼 >Informix SQL에서 일대다 관계를 쉼표로 구분된 목록으로 표시하는 방법은 무엇입니까?

Informix SQL에서 일대다 관계를 쉼표로 구분된 목록으로 표시하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-03 17:29:40275검색

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으로 문의하세요.