> 데이터 베이스 > MySQL 튜토리얼 > STRING_SPLIT 없이 SQL Server 2012에서 쉼표로 구분된 값을 분할하는 방법은 무엇입니까?

STRING_SPLIT 없이 SQL Server 2012에서 쉼표로 구분된 값을 분할하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-11 06:30:42
원래의
216명이 탐색했습니다.

How to Split Comma-Separated Values in SQL Server 2012 without STRING_SPLIT?

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿