日期:2014-05-18  浏览次数:20729 次

如何分解这个字符串
EXEC SP_MDealBillListCheck 't_OtherInList','10663,10662,10661,10660','管理员','XUGR','1'


'10663,10662,10661,10660' 这个字符串实际是多个数据行的表单号,然后我对这个表单进行批量审核


我希望分解后插入一个临时表,如下

A表
10663
10662
10661
10660


然后我再用游标一个个处理



------解决方案--------------------
SQL code
if object_id('f_split')is not null drop function  f_split
go
create function 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
select * from dbo.f_split('11,2,3',',')
/*
col
----
11
2
3
(3 個資料列受到影響)
*/

------解决方案--------------------
SQL code

declare @M varchar(50),
        @N xml
        
set @M='10663,10662,10661,10660'

set @N=convert(xml,'<r><c>'+replace(@M,',','</c><c>')+'</c></r>')
select col=T.c.value('.[1]','varchar(20)')
from @N.nodes('/r/c') T(c)
/*
col
--------------------
10663
10662
10661
10660
*/