>데이터 베이스 >MySQL 튜토리얼 >MySQL 쿼리 결과를 쉼표로 구분된 목록으로 검색하려면 어떻게 해야 합니까?

MySQL 쿼리 결과를 쉼표로 구분된 목록으로 검색하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-17 02:13:10962검색

How Can I Retrieve MySQL Query Results as a Comma-Separated List?

MySQL 쿼리 결과를 쉼표로 구분된 목록으로 가져오기

MySQL에서는 쿼리 결과를 쉼표로 구분된 목록으로 검색해야 할 수도 있습니다. 하위 쿼리를 사용하여 특정 정보를 추출할 수 있지만 원하는 형식으로 데이터를 표시하는 데는 몇 가지 제한 사항이 있습니다.

질문:

다음 쿼리를 고려해 보세요.

<code class="language-sql">SELECT p.id, p.name, 
       (SELECT name 
          FROM sites s 
         WHERE s.id = p.site_id) AS site_list
  FROM publications p</code>

하위 쿼리는 각 사이트 이름을 별도의 열로 반환하는데, 이는 원하는 쉼표로 구분된 목록 결과와 일치하지 않습니다.

해결책:

MySQL은 이러한 목표를 달성하기 위해 GROUP_CONCAT 기능을 제공합니다. 이 기능을 활용하면 다음과 같이 쿼리를 수정할 수 있습니다.

<code class="language-sql">SELECT p.id, p.name, GROUP_CONCAT(s.name) AS site_list
FROM sites s
INNER JOIN publications p ON(s.id = p.site_id)
GROUP BY p.id, p.name;</code>

GROUP_CONCAT 지정된 열(이 경우 "사이트" 테이블의 "이름" 열)의 값을 연결하고 미리 정의된 구분 기호(일반적으로 쉼표)로 구분합니다. 그런 다음 결과는 "게시물" 테이블의 "id" 및 "name" 열별로 그룹화되어 각 출판물 및 관련 사이트에 대한 고유한 레코드를 제공하며 쉼표로 구분된 목록으로 표시됩니다.

위 내용은 MySQL 쿼리 결과를 쉼표로 구분된 목록으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.