SQL语言中对字符串的处理能力比较弱,简单的一个字符串分割都是如此麻烦!
--创建函数
create function f_splitstr
(
@SourceSql varchar(8000),
@StrSeprate varchar(10)
)
returns @temp table(F1 varchar(100))
as
begin
declare @i int
set @SourceSql=rtrim(ltrim(@SourceSql))
set @i=charindex(@StrSeprate,@SourceSql)
while @i>=1
begin
insert @temp values(left(@SourceSql,@i-1))
set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)
set @i=charindex(@StrSeprate,@SourceSql)
end
if @SourceSql<>''
insert @temp values(@SourceSql)
return
end
--执行
select * from dbo.f_splitstr('01,02,03',',')
执行结果:
执行的时候注意:创建函数和执行函数要分别执行,否则执行不成功。