Heim > Datenbank > MySQL-Tutorial > Wie teile ich durch Kommas getrennte Werte in SQL Server 2012 ohne STRING_SPLIT auf?

Wie teile ich durch Kommas getrennte Werte in SQL Server 2012 ohne STRING_SPLIT auf?

DDD
Freigeben: 2025-01-11 06:30:42
Original
216 Leute haben es durchsucht

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

Alternativen zu STRING_SPLIT in SQL Server 2012

Die STRING_SPLIT-Funktion ist in SQL Server 2012 aufgrund von Kompatibilitätsbeschränkungen nicht verfügbar. Eine Änderung des Kompatibilitätsgrads ist zwar nicht möglich, es gibt jedoch eine Alternative zur Aufteilung durch Kommas getrennter Werte.

Verwendung von XML-Methoden und CROSS APPLY

XML-Methoden und CROSS APPLY können verwendet werden, um die gewünschten Ergebnisse zu erzielen. So funktioniert es:

<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>
Nach dem Login kopieren

Beispiel

Betrachten Sie das folgende Beispiel, in dem der @ID-Parameter durch Kommas getrennte Werte enthält:

<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>
Nach dem Login kopieren

Die Ausgabe der obigen Abfrage lautet:

<code>DATA
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20</code>
Nach dem Login kopieren

Zusammenfassung

Während STRING_SPLIT in SQL Server 2012 nicht verfügbar ist, bietet die XML-Methode in Kombination mit CROSS APPLY eine praktikable Alternative zum Teilen von durch Kommas getrennten Werten. Dieser Ansatz ist besonders nützlich, wenn Einschränkungen des Kompatibilitätsgrads Datenbankänderungen verhindern.

Das obige ist der detaillierte Inhalt vonWie teile ich durch Kommas getrennte Werte in SQL Server 2012 ohne STRING_SPLIT auf?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage