[原创]把","号分隔的字串转化成一列的Table

本文介绍了一个SQL Server自定义函数ufn_ConvertToIntList,该函数将输入的逗号分隔的数字字符串转换为整数列表。通过示例展示了如何使用此函数批量处理大量数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

None.gifalter function dbo.ufn_ConvertToIntList
None.gif(
None.gif 
@data varchar(7990)
None.gif)
None.gif
returns @table Table(c int not null)
None.gif
as
None.gif
begin
None.gif    
declare @str varchar(8000),@iter varchar(50)
None.gif            ,
@beginPos int@endPos int
None.gif    
select @str= @data + ','@beginPos = 1@endPos = charindex(','@str@beginPos)
None.gif    
while(@endPos > 0)
None.gif    
begin
None.gif        
set @iter = SubString(@str,@beginPos ,@endPos - @beginPos )
None.gif        
if(@iter <> '')
None.gif        
begin 
None.gif            
insert into @table(c) values(Convert(int,@iter))
None.gif        
end
None.gif        
select @beginPos =  @endPos + 1@endPos = charindex(','@str@beginPos)
None.gif    
end
None.gif    
return
None.gif
end
None.gif
go
None.gif
None.gif
declare @data varchar(8000)
None.gif        ,
@i int
None.gif    
select @i = 1@data ='1,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9,2,3,4,5,6,7,8,9'
None.gif
while(@i < 20)
None.gif
begin
None.gif    
select * from dbo.ufn_ConvertToIntList(@data)
None.gif    
set @i= @i +1
None.gif
end
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值