わかりました、これがあなたにとってどれほど良いか、またはパフォーマンスがどれほど良いかはわかりませんが、過去に同様のことを達成するために使用したコードを次に示します。
CREATE FUNCTION [dbo].[Split](
@list ntext
)
RETURNS @tbl TABLE (listpos int IDENTITY(1, 1) NOT NULL,
number int NOT NULL)
AS
BEGIN
DECLARE @pos int,
@textpos int,
@chunklen smallint,
@str nvarchar(4000),
@tmpstr nvarchar(4000),
@leftover nvarchar(4000)
SET @textpos = 1
SET @leftover = ''
WHILE @textpos <= datalength(@list) / 2
BEGIN
SET @chunklen = 4000 - datalength(@leftover) / 2
SET @tmpstr = ltrim(@leftover + substring(@list, @textpos, @chunklen))
SET @textpos = @textpos + @chunklen
SET @pos = charindex(',', @tmpstr)
WHILE @pos > 0
BEGIN
SET @str = substring(@tmpstr, 1, @pos - 1)
INSERT @tbl (number) VALUES(convert(int, @str))
SET @tmpstr = ltrim(substring(@tmpstr, @pos + 1, len(@tmpstr)))
SET @pos = charindex(',', @tmpstr)
END
SET @leftover = @tmpstr
END
IF ltrim(rtrim(@leftover)) <> ''
INSERT @tbl (number) VALUES(convert(int, @leftover))
RETURN
END
次に、他のストアド プロシージャで、次のようにコンマで区切られた ID の文字列を渡すことができます。
select a.number from split('1,2,3') a inner join myothertable b on a.number = b.ID
私が言うように、これはおそらく本当に悪いことです。なぜなら、これには多くの文字列操作が含まれており、関数をどこから取得したか思い出せません...しかし、それは選択するためにそこにあります...
元の文字列にインデックスを付ける必要が本当にない場合は、 listpos 列に入力するビットを取り除くこともできると思います。