代码改变世界

SQL语句实现分割字符串

2006-10-09 12:09  Koy  阅读(1195)  评论(0编辑  收藏  举报
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',',')

执行结果:
uploads/200508/19_124902_db_select.jpg


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