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 중국어 웹사이트의 기타 관련 기사를 참조하세요!