CSV, CDF string – Multiple In by string IN(“1,2,3,4,5″) etc
January 27th, 2009
No comments
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
Categories: SQL