这是从将一个充满逗号分隔值的 varchar 传递给 SQL Server IN 函数开始的。
我想拆分一些逗号分隔的文本,但我需要允许嵌入逗号:
DECLARE @text NVARCHAR(1000) = 'abc,def,"ghi,jkl",mno';
我期待的结果是:
abc
def
ghi,jkl
mno
这是我用来分割 CSV 文本的函数。
它使用一个循环,所以如果性能是一个问题,你可以使用这里的建议来调整它:https ://stackoverflow.com/a/878964/482595
CREATE FUNCTION uf_Split
(
@Text NVARCHAR(MAX),
@Delimiter CHAR(1),
@Quote CHAR(1)
)
RETURNS @Result TABLE
(
[Index] INT NOT NULL IDENTITY(1, 1),
[Value] NVARCHAR(4000) NULL,
[CharPos] INT
)
AS
BEGIN
DECLARE @start BIGINT; SET @start = 1
DECLARE @end BIGINT; SET @end = 1
IF @Text is null
BEGIN
RETURN
END
WHILE 1=1
BEGIN
SET @end =
CASE
WHEN CHARINDEX(@Quote, @Text, @start) = @start THEN CHARINDEX(@Quote + @Delimiter, @Text, @start + 1)
ELSE CHARINDEX(@Delimiter, @Text, @start)
END
IF ISNULL(@end, 0) = 0
BEGIN
-- Delimiter could not be found in the remainder of the text:
INSERT @Result([Value], [CharPos]) VALUES(SUBSTRING(@Text, @start, DATALENGTH(@Text)), @start)
BREAK
END
ELSE IF (CHARINDEX(@Quote, @Text, @start) = @start) AND (CHARINDEX(@Quote + @Delimiter, @Text, @start + 1) = @end)
BEGIN
INSERT @Result([Value], [CharPos]) VALUES(SUBSTRING(@Text, @start + 1, @end - @start - 1), @start)
SET @start = @end + 2
END
ELSE
BEGIN
INSERT @Result([Value], [CharPos]) VALUES(SUBSTRING(@Text, @start, @end - @start), @start)
SET @start = @end + 1
END
END
RETURN
END
GO