电竞比分网-中国电竞赛事及体育赛事平台

分享

根據(jù)字符分割字符串的三種寫法

 zww_blog 2012-03-15

根據(jù)字符分割字符串的三種寫法

分類: SQL函數(shù)分享系列

go

--創(chuàng)建函數(shù)(第一版)

create function [dbo].[m_split](@c varchar(2000),@split varchar(2))  

    returns @t table(col varchar(200))  

as  

begin  

      while(charindex(@split,@c)<>0)  

        begin  

          insert @t(col) values (substring(@c,1,charindex(@split,@c)-1))  

          set @c = stuff(@c,1,charindex(@split,@c),'')  

        end  

      insert @t(col) values (@c)  

      return  

end

 

--下面兩種是在論壇看到高手們發(fā)的

go

--創(chuàng)建函數(shù)(第二版)(fredrickhu(F))

create function [dbo].[f_split](@s varchar(8000), @split varchar(10) )

returns table

as

 return

 (select substring(@s,number,charindex(@split,@s+@split,number)-number)as col

  from master..spt_values

  where type='p' and number<=len(@s+'a')

  and charindex(@split,@split+@s,number)=number)

 

go

--創(chuàng)建函數(shù)(第三版)(dawugui(愛新覺羅.毓華))

create function [dbo].[d_split] (@inputstr varchar(8000),@seprator varchar(10))

returns @temp table (varchar(200))

as

begin

  declare @i int

  set @inputstr = rtrim(ltrim(@inputstr))

  set @i = charindex(@seprator, @inputstr)

  while @i >= 1

  begin

    insert @temp values(left(@inputstr, @i - 1))

    set @inputstr = substring(@inputstr, @i + 1, len(@inputstr) - @i)

    set @i = charindex(@seprator, @inputstr)

  end

  if @inputstr <> '/'

  insert @temp values(@inputstr)

  return

end

 

--測試示例

declare @sql varchar(20)

set @sql='A,B,C,D,E'

 

select * from dbo.m_split(@sql,',')

select * from dbo.f_split(@sql,',')

select * from dbo.d_split(@sql,',')

 

--運行結(jié)果(結(jié)果是相同的)

/*

col

---------

A

B

C

D

E

*/

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多