问题描述:
请问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')