郫县房价新房现房出售:sql server 用户自定义行集如何实现逗号分隔字符的转换为行集

来源:百度文库 编辑:高考问答 时间:2024/05/06 03:53:57
请问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')