SQL Server 2012의 STRING_SPLIT 대안
호환성 수준 제한으로 인해 SQL Server 2012에서는 STRING_SPLIT 함수를 사용할 수 없습니다. 호환성 수준을 변경할 수는 없지만 쉼표로 구분된 값을 분할하는 방법이 있습니다.
XML 방법 및 CROSS APPLY 사용
XML 메소드와 CROSS APPLY를 사용하여 원하는 결과를 얻을 수 있습니다. 작동 방식은 다음과 같습니다.
<code class="language-sql">SELECT Split.a.value('.', 'NVARCHAR(MAX)') AS DATA FROM ( SELECT CAST('<X>'+REPLACE(@ID, ',', '</X><X>')+'</X>' AS XML) AS String ) AS A CROSS APPLY String.nodes('/X') AS Split(a);</code>
예
@ID 매개변수에 쉼표로 구분된 값이 포함된 다음 예를 고려해 보세요.
<code class="language-sql">DECLARE @ID NVARCHAR(300) = '1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20';</code>
위 쿼리의 결과는 다음과 같습니다.
<code>DATA 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20</code>
요약
SQL Server 2012에서는 STRING_SPLIT를 사용할 수 없지만 CROSS APPLY와 결합된 XML 방법은 쉼표로 구분된 값을 분할하기 위한 실행 가능한 대안을 제공합니다. 이 접근 방식은 호환성 수준 제한으로 인해 데이터베이스 수정이 방지될 때 특히 유용합니다.
위 내용은 STRING_SPLIT 없이 SQL Server 2012에서 쉼표로 구분된 값을 분할하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!