CSV, CDF string – Multiple In by string IN(“1,2,3,4,5″) etc
January 27th, 2009
CREATE FUNCTION CSVTable(@Str varchar(7000)) returns @t TABLE (numberval int, stringval varchar(100), DateVal datetime) AS begin declare @i int; declare @c varchar(100); SET @Str = @Str + ',' SET @i = 1; SET @c = ''; while @i <= len(@Str) begin IF substring(@Str,@i,1) = ',' begin INSERT INTO @t VALUES (CASE WHEN isnumeric(@c)=1 THEN @c else NULL END, rtrim(ltrim(@c)), CASE WHEN isdate(@c)=1 then @c else NULL END) SET @c = '' end else SET @c = @c + substring(@Str,@i,1) SET @i = @i +1 end RETURN end
Note that the above works for all datatypes — dates or text or numbers (ints only, but that could be fixed as well).
So, for example:
SELECT * FROM People WHERE People.Name IN (SELECT StringVal FROM dbo.CSVTable('Jeff,Bill,Pete,Eddy, John,Mike')) SELECT * FROM Numbers WHERE Numbers.Number IN (SELECT numberval FROM dbo.CSVTable('1,2,34,5,5,6,7,8')) SELECT * FROM Dates WHERE Dates.Date IN (SELECT dateval FROM dbo.CSVTable ('1/1/2000','1/2/2000','1/3/2000'))
Of course, the function works with @variables or fieldnames or any other expression:
SELECT * FROM dbo.CSVTable(@ListOfNames)
Categories: SQL