আপনাকে এসও হিসাবে উল্লেখ করা বা এখানে এটির উত্তর দেওয়ার মধ্যে আমি ছিন্ন হয়ে পড়েছি, 'কারণ এটি প্রায় একটি প্রোগ্রামিং প্রশ্ন। তবে যেহেতু আমি ইতিমধ্যে আমার কাছে একটি সমাধান পেয়েছি ... আমি এটি পোস্ট করব;)
এইটি যেভাবে কাজ করে তা হ'ল আপনি কোনও কমা সীমাবদ্ধ স্ট্রিং (সরল বিভাজন, সিএসভি স্টাইল বিভাজন করেন না) ভ্যারিচার (4000) হিসাবে সঞ্চিত পদ্ধতিতে খাওয়ান এবং তারপরে সেই তালিকাটি এই ফাংশনে ফিড করুন এবং একটি সহজ টেবিলটি ফিরে পাবেন, শুধু বারচারের একটি টেবিল।
এটি আপনাকে প্রক্রিয়াকরণ করতে চাইলে কেবলমাত্র আইডির মান পাঠাতে দেয় এবং আপনি সেই মুহুর্তে একটি সাধারণ যোগদান করতে পারেন।
পর্যায়ক্রমে আপনি একটি সিএলআর ডেটা টেবিলের সাহায্যে কিছু করতে পারেন এবং এতে ফিড দিতে পারেন তবে এটি সমর্থন করার জন্য আরও কিছুটা ওভারহেড এবং প্রত্যেকে সিএসভি তালিকা বুঝতে পারে।
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