自己攒机攻略:sql server 用户自定义行集如何实现逗号分隔字符的转换为行集

来源:百度文库 编辑:杭州交通信息网 时间:2024/04/30 12:12:35
请问sql server 2k 自定义函数如何实现:
参数 : @aString
类型 Verchar
返回一个表:
如传入: “abcd,efg,mm,.."
要得到结果
abcd
efg
mm
...

就是说用函数实现逗号分隔字符串的转换,得到行集,谢谢

create function f_split(@SourceSql varchar(8000))
returns @temp table(a varchar(100))
as
begin
declare @i int
set @SourceSql=rtrim(ltrim(@SourceSql))
set @i=charindex(',',@SourceSql)
while @i>=1
begin
insert @temp values(left(@SourceSql,@i-1))
set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)
set @i=charindex(',',@SourceSql)
end
if @SourceSql<>','
insert @temp values(@SourceSql)
return
end

用法 select * from dbo.f_split('abcd,efg,mm')