고유 값 및 연결을 위해 SQL Server의 STRING_AGG 사용
SQL Server의 STRING_AGG 함수는 여러 행의 값을 효율적으로 연결합니다. 그러나 고유한 값과 연결된 문자열을 직접 얻으려면 약간 더 복잡한 접근 방식이 필요합니다. 문제는 COUNT(DISTINCT ...)
의 기능을 문자열 집계
일반적인 해결 방법은 2단계 그룹화 프로세스입니다. 첫 번째 GROUP BY
절은 관련 열(예: State, City, Siting)의 고유한 조합을 식별하여 중복을 제거합니다. 그런 다음 두 번째 GROUP BY
는 STRING_AGG를 사용하여 고유한 값을 연결하여 이러한 고유한 조합을 집계합니다. 이 방법은 고유 값의 개수와 연결된 문자열을 모두 제공합니다.
다음은 이 기술을 보여주는 예입니다.
<code class="language-sql">WITH Sitings AS ( SELECT * FROM (VALUES (1, 'Florida', 'Orlando', 'bird'), (2, 'Florida', 'Orlando', 'dog'), (3, 'Arizona', 'Phoenix', 'bird'), (4, 'Arizona', 'Phoenix', 'dog'), (5, 'Arizona', 'Phoenix', 'bird'), (6, 'Arizona', 'Phoenix', 'bird'), (7, 'Arizona', 'Phoenix', 'bird'), (8, 'Arizona', 'Flagstaff', 'dog') ) AS F (ID, State, City, Siting) ), CTE_Animals AS ( SELECT State, City, Siting FROM Sitings GROUP BY State, City, Siting ) SELECT State, City, COUNT(*) AS [# Of Sitings], STRING_AGG(Siting, ',') AS Animals FROM CTE_Animals GROUP BY State, City ORDER BY State, City;</code>
이 쿼리는 도시 및 주별로 뚜렷한 동물 목격 사례를 보여주는 결과 세트를 생성합니다.
<code>+---------+-----------+--------------+----------+ | State | City | # Of Sitings | Animals | +---------+-----------+--------------+----------+ | Arizona | Flagstaff | 1 | dog | | Arizona | Phoenix | 2 | bird,dog | | Florida | Orlando | 2 | bird,dog | +---------+-----------+--------------+----------+</code>
긴 문자열 처리:
연결된 사이트 문자열이 varchar
의 8000자 제한을 초과하는 경우 잘림을 방지하려면 Siting
을 사용하기 전에 varchar(max)
열을 STRING_AGG
으로 명시적으로 캐스팅해야 합니다.
<code class="language-sql">STRING_AGG(CAST(Siting AS VARCHAR(MAX)), ',') AS Animals</code>
이렇게 하면 연결된 문자열이 더 긴 결과를 수용할 수 있습니다.
위 내용은 SQL Server의 STRING_AGG를 사용하여 고유한 값과 연결된 문자열을 얻으려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!