create function f_str_split(@str_in AS VARCHAR(max),@split as varchar(2) =',') RETURNS @keylst TABLE(keyval varchar (50)) BEGIN declare @idx1 int,@idx2 int,@key varchar(50) set @idx1 = 1 set @idx2 = 0 if isnull(@split,'') = '' set @split = '|' if right(@str_in,1) <> @split set @str_in = @str_in + @split while 1=1 begin set @idx2 = CharIndex(@split,@str_in,@idx2 + 1); if @idx2 <= 0 break --print '@idx1 ' + cast(@idx1 as varchar) + ' @idx2 ' + cast(@idx2 as varchar) insert into @keylst select substring(@str_in,@idx1,@idx2 - @idx1); --print @key; set @idx1 = @idx2 + 1; end return; end go select * from f_str_split('1,2,3,4',',')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。