sql server中对字符串实现Split操作

本文介绍了一个SQL函数SplitString,用于将输入的字符串按照指定分隔符进行分割,并返回包含分割后值的表格。同时提供了使用示例。

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

先来一个函数,该函数将帮助你对字符串进行分割

 1 CREATE function [dbo].[SplitString]
 2 (
 3     @Input nvarchar(max),
 4     @Separator nvarchar(max)=',', 
 5     @RemoveEmptyEntries bit=1 
 6 )
 7 returns @TABLE table 
 8 (
 9     [Id] int identity(1,1),
10     [Value] nvarchar(max)
11 ) 
12 as
13 begin 
14     declare @Index int, @Entry nvarchar(max)
15     set @Index = charindex(@Separator,@Input)
16 
17     while (@Index>0)
18     begin
19         set @Entry=ltrim(rtrim(substring(@Input, 1, @Index-1)))
20         
21         if (@RemoveEmptyEntries=0) or (@RemoveEmptyEntries=1 and @Entry<>'')
22             begin
23                 insert into @TABLE([Value]) Values(@Entry)
24             end
25 
26         set @Input = substring(@Input, @Index+datalength(@Separator)/2, len(@Input))
27         set @Index = charindex(@Separator, @Input)
28     end
29     
30     set @Entry=ltrim(rtrim(@Input))
31     if (@RemoveEmptyEntries=0) or (@RemoveEmptyEntries=1 and @Entry<>'')
32         begin
33             insert into @TABLE([Value]) Values(@Entry)
34         end
35 
36     return
37 end
38 GO
View Code

 

下面来点使用说明,仅供参考

1 declare @fields varchar(500)
2 set @fields = 'SalesOrderID,SalesOrderDetailID,CarrierTrackingNumber,OrderQty,ProductID,SpecialOfferID,UnitPrice,UnitPriceDiscount,LineTotal,rowguid,ModifiedDate'
3 select Id,Value from dbo.SplitString(@fields,',',1)
View Code

效果如下:(id,value都有,就不用担心如何取哪一行的数据)

 

 

转载于:https://www.cnblogs.com/hogan/p/3232602.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值