這是從Passing a varchar full of comma delimited values to a SQL Server IN function開始的。在SQL Server中拆分帶引號的分隔符的分隔文本
我想分割一些逗號分隔的文字,但我需要允許嵌入的逗號:
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
在大多數語言中這是一個不平凡的主張。使用正則表達式非常困難。您通常最擅長使用專門用於處理分割CSV格式的代碼/函數。這可能是可行的;但它可能不會很有趣。 –