SQL Server 自定义字符串分割函数
2016-07-15 15:20
375 查看
一、按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果(标量值函数)
调用示例:select dbo.Func_StrArrayLength('78,1,2,3',',')
返回值:4
二、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便(标量值函数)
调用示例:select dbo.Func_StrArrayStrOfIndex('8,9,4',',',2)
返回值:9
三、结合上边两个函数,像数组一样遍历字符串中的元素(表值函数)
----调用
select * from dbo.Func_SplitStr('1,2,3,4',',')
--结果:
1
2
3
4
另一种方式(表值函数):
----调用
select * from dbo.Func_SplitStr('1,2,3,4',',')
--结果:
1
2
3
4
create function Func_StrArrayLength ( @str varchar(1024), --要分割的字符串 @split varchar(10) --分隔符号 ) returns int as begin declare @location int declare @start int declare @length int set @str=ltrim(rtrim(@str)) set @location=charindex(@split,@str) set @length=1 while @location<>0 begin set @start=@location+1 set @location=charindex(@split,@str,@start) set @length=@length+1 end return @length end go
调用示例:select dbo.Func_StrArrayLength('78,1,2,3',',')
返回值:4
二、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便(标量值函数)
create function Func_StrArrayStrOfIndex ( @str varchar(1024), --要分割的字符串 @split varchar(10), --分隔符号 @index int --取第几个元素 ) returns varchar(1024) as begin declare @location int declare @start int declare @next int declare @seed int set @str=ltrim(rtrim(@str)) set @start=1 set @next=1 set @seed=len(@split) set @location=charindex(@split,@str) while @location<>0 and @index>@next begin set @start=@location+@seed set @location=charindex(@split,@str,@start) set @next=@next+1 end if @location =0 select @location =len(@str)+1 --这儿存在两种情况:、字符串不存在分隔符号2、字符串中存在分隔符号,跳出while循环后,@location为,那默认为字符串后边有一个分隔符号。 return substring(@str,@start,@location-@start) end go
调用示例:select dbo.Func_StrArrayStrOfIndex('8,9,4',',',2)
返回值:9
三、结合上边两个函数,像数组一样遍历字符串中的元素(表值函数)
create function Func_SplitStr(@SourceSql varchar(8000), @StrSeprate varchar(100)) returns @temp table(F1 varchar(100)) as begin declare @ch as varchar(100) set @SourceSql=@SourceSql+@StrSeprate while(@SourceSql<>'') begin set @ch=left(@SourceSql,charindex(',',@SourceSql,1)-1) insert @temp values(@ch) set @SourceSql=stuff(@SourceSql,1,charindex(',',@SourceSql,1),'') end return end go
----调用
select * from dbo.Func_SplitStr('1,2,3,4',',')
--结果:
1
2
3
4
另一种方式(表值函数):
create function Func_SplitStr(@str nvarchar(2000),@split nvarchar(2)) returns @t table(AccountCodeID int ) as begin declare @tmpAccountCodeID int,@getIndex int set @getIndex=charindex(',',@str) while(@getIndex<>0) begin set @tmpAccountCodeID=convert(int,substring(@str,1,@getIndex-1)) insert into @t(AccountCodeID) values (@tmpAccountCodeID) set @str=stuff(@str,1,@getIndex,'') set @getIndex=charindex(',',@str) end insert into @t(AccountCodeID) values (@str) return end go
----调用
select * from dbo.Func_SplitStr('1,2,3,4',',')
--结果:
1
2
3
4
相关文章推荐
- 云服务器ubuntu-14.01.1系统安装mysql5.6.28(deb-bundle包)
- node.js连接mysql的方法
- Oracle expdp/impdp导出导入命令及数据库备份
- Oracle SCN与检查点
- SQL Server 2008中利用merge into关键实现insert/update自动匹配(类似于MySQL中的For Update关键字)
- Windows下安装redis
- session 加入redis的实现代码
- oracle 死锁现象重现,查询及处理
- 15. 试用vSphere 6(三):安装vCenter 6(独立数据库)之:数据库服务器安装与配置
- sqlserver2008中主要的系统表说明
- Kafka - SQL 引擎分享
- 14. 试用vSphere 6(三):安装vCenter 6(独立数据库)之:域控服务器安装与配置
- mysql replace into,insert into ... on duplicate key
- 处理mysql tokudb引擎无法启用问题一例
- mysql中日期比较大小方法详解
- session 加入mysql库的方法
- oracle数据库时间转换
- redis的C/C++ API
- Mysql 查看使用命令行查看数据库和表,字段等信息
- 不能远程连接mysql解决方法