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',',')


执行结果:



执行的时候注意:创建函数和执行函数要分别执行,否则执行不成功。