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>
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>
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>
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!