मैं आपको एसओ को संदर्भित करने या यहां इसका जवाब देने के बीच फट गया हूं, 'क्योंकि यह लगभग एक प्रोग्रामिंग सवाल है। लेकिन जब से मुझे पहले से ही एक समाधान मिला है जिसका मैं उपयोग करता हूं ... मैं इसे पोस्ट करूंगा;)
जिस तरह से यह काम करता है वह है आप एक अल्पविराम सीमांकित स्ट्रिंग (सरल विभाजन, CSV शैली विभाजन को नहीं करता है) को varchar (4000) के रूप में संग्रहीत कार्यविधि में फीड करें और फिर उस सूची को इस फ़ंक्शन में फ़ीड करें और एक आसान तालिका वापस प्राप्त करें, बस varchars की एक तालिका।
यह आपको केवल उन आईडी के मूल्यों को भेजने की अनुमति देता है जिन्हें आप संसाधित करना चाहते हैं, और आप उस बिंदु पर एक साधारण जुड़ाव कर सकते हैं।
वैकल्पिक रूप से आप सीएलआर डेटाटेबल के साथ कुछ कर सकते हैं और उस में फ़ीड कर सकते हैं, लेकिन यह समर्थन के लिए थोड़ा अधिक उपरि है और हर कोई सीएसवी सूचियों को समझता है।
USE [Database]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[splitListToTable] (@list nvarchar(MAX), @delimiter nchar(1) = N',')
RETURNS @tbl TABLE (value varchar(4000) NOT NULL) AS
/*
http://www.sommarskog.se/arrays-in-sql.html
This guy is apparently THE guy in SQL arrays and lists
Need an easy non-dynamic way to split a list of strings on input for comparisons
Usage like thus:
DECLARE @sqlParam VARCHAR(MAX)
SET @sqlParam = 'a,b,c'
SELECT * FROM (
select 'a' as col1, '1' as col2 UNION
select 'a' as col1, '2' as col2 UNION
select 'b' as col1, '3' as col2 UNION
select 'b' as col1, '4' as col2 UNION
select 'c' as col1, '5' as col2 UNION
select 'c' as col1, '6' as col2 ) x
WHERE EXISTS( SELECT value FROM splitListToTable(@sqlParam,',') WHERE x.col1 = value )
*/
BEGIN
DECLARE @endpos int,
@startpos int,
@textpos int,
@chunklen smallint,
@tmpstr nvarchar(4000),
@leftover nvarchar(4000),
@tmpval nvarchar(4000)
SET @textpos = 1
SET @leftover = ''
WHILE @textpos <= datalength(@list) / 2
BEGIN
SET @chunklen = 4000 - datalength(@leftover) / 2
SET @tmpstr = @leftover + substring(@list, @textpos, @chunklen)
SET @textpos = @textpos + @chunklen
SET @startpos = 0
SET @endpos = charindex(@delimiter, @tmpstr)
WHILE @endpos > 0
BEGIN
SET @tmpval = ltrim(rtrim(substring(@tmpstr, @startpos + 1,
@endpos - @startpos - 1)))
INSERT @tbl (value) VALUES(@tmpval)
SET @startpos = @endpos
SET @endpos = charindex(@delimiter, @tmpstr, @startpos + 1)
END
SET @leftover = right(@tmpstr, datalength(@tmpstr) / 2 - @startpos)
END
INSERT @tbl(value) VALUES (ltrim(rtrim(@leftover)))
RETURN
END