ここで提案されているインラインソリューション:文字列を分割してアイテムxにアクセスできるようにするにはどうすればよいですか?by vzczcは、再帰の深さの制限があるため、100未満の要素を含む文字列に対してのみ機能します(UDF内で制限を変更することはできません)。
長い文字列を優れたパフォーマンスで分割する他の方法はありますか?私が使用している(インラインではない)UDFは非常に遅いです:
CREATE FUNCTION [dbo].[fn_ParseDelimitedStrings](@String nvarchar(MAX), @Delimiter char(1))
RETURNS @Values TABLE
(
RowId int Not Null IDENTITY(1,1) PRIMARY KEY
,Value nvarchar(255) Not Null
)
AS
BEGIN
DECLARE @startPos smallint
,@endPos smallint
IF (@String = '')
RETURN
IF (RIGHT(@String, 1) != @Delimiter)
SET @String = @String + @Delimiter
SET @startPos = 1
SET @endPos = CharIndex(@Delimiter, @String)
WHILE @endPos > 0
BEGIN
INSERT @Values(Value)
SELECT LTRIM(RTRIM(SUBSTRING(@String, @startPos, @endPos - @startPos)))
-- remove the delimiter just used
SET @String = STUFF(@String, @endPos, 1, '')
-- move string pointer to next delimiter
SET @startPos = @endPos
SET @endPos = CHARINDEX(@Delimiter, @String)
END
RETURN
END