本文主要是介绍SQL SERVER分隔函数,根据传入值,获取第几个分隔的值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这个题目描述的有点乱,大家看需求吧,论坛帖子的需求, 实现类似程序中,可以用string[] arr=“1.12.123”.split(.) 如果我要取12 则可以arr[1]。
CREATE FUNCTION dbo.F_SplitByIdex(@SplitString nvarchar(max), --源字符串@Separator nvarchar(10)=' ', --分隔符号,默认为空格@index INT)RETURNS NVARCHAR(200)ASBEGINDECLARE @CurrentIndex int;DECLARE @NextIndex int;DECLARE @ReturnText nvarchar(max);DECLARE @SplitStringsTable TABLE --输出的数据表([id] int identity(1,1),[value] nvarchar(max))SELECT @CurrentIndex=1;WHILE(@CurrentIndex<=len(@SplitString))BEGINSELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);IF(@NextIndex=0 OR @NextIndex IS NULL)SELECT @NextIndex=len(@SplitString)+1;SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);SELECT @CurrentIndex=@NextIndex+1;ENDSET @ReturnText = (SELECT TOP 1 value FROM @SplitStringsTable WHERE id= @index+1)RETURN @ReturnTextEND
GO
测试如下:
Declare @str varchar(10)='1.12.123'
SELECT dbo.F_SplitByIdex(@str,'.',0) --中间的是分隔符可以是逗号、句号、分号等
结果:
这篇关于SQL SERVER分隔函数,根据传入值,获取第几个分隔的值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!