als u geen tabelwaardeparameters kunt gebruiken, zie:"Arrays en lijsten in SQL Server 2008 met behulp van tabelwaardeparameters" door Erland Sommarskog , dan zijn er veel manieren om strings in SQL Server te splitsen. Dit artikel behandelt de voor- en nadelen van zowat elke methode:
U moet een splitfunctie maken. Zo kan een splitsingsfunctie worden gebruikt:
SELECT
*
FROM YourTable y
INNER JOIN dbo.yourSplitFunction(@Parameter) s ON y.ID=s.Value
Ik geef de voorkeur aan de getallentabelbenadering om een string in TSQL te splitsen maar er zijn talloze manieren om strings in SQL Server te splitsen, zie de vorige link, waarin de voor- en nadelen van elk worden uitgelegd.
Om de Numbers Table-methode te laten werken, moet u deze eenmalige tijdtabelconfiguratie uitvoeren, waardoor een tabel Numbers
wordt gemaakt die rijen van 1 tot 10.000 bevat:
SELECT TOP 10000 IDENTITY(int,1,1) AS Number
INTO Numbers
FROM sys.objects s1
CROSS JOIN sys.objects s2
ALTER TABLE Numbers ADD CONSTRAINT PK_Numbers PRIMARY KEY CLUSTERED (Number)
Zodra de Numbers-tabel is ingesteld, maakt u deze splitsfunctie:
CREATE FUNCTION [dbo].[FN_ListToTable]
(
@SplitOn char(1) --REQUIRED, the character to split the @List string on
,@List varchar(8000)--REQUIRED, the list to split apart
)
RETURNS TABLE
AS
RETURN
(
----------------
--SINGLE QUERY-- --this will not return empty rows
----------------
SELECT
ListValue
FROM (SELECT
LTRIM(RTRIM(SUBSTRING(List2, number+1, CHARINDEX(@SplitOn, List2, number+1)-number - 1))) AS ListValue
FROM (
SELECT @SplitOn + @List + @SplitOn AS List2
) AS dt
INNER JOIN Numbers n ON n.Number < LEN(dt.List2)
WHERE SUBSTRING(List2, number, 1) = @SplitOn
) dt2
WHERE ListValue IS NOT NULL AND ListValue!=''
);
GO
U kunt nu eenvoudig een CSV-tekenreeks in een tabel splitsen en eraan deelnemen:
select * from dbo.FN_ListToTable(' ','stack over flow')
UITGANG:
ListValue
-------------------
stack
over
flow
(3 row(s) affected)