SQL里类似SPLIT的分割字符串函数

 更新时间:2011年04月20日 01:24:29   作者:  
SQL对字符串的处理能力比较弱,比如我要循环遍历象1,2,3,4,5这样的字符串,如果用数组的话,遍历很简单,但是T-SQL不支持数组,所以处理下来比较麻烦。下边的函数,实现了象数组一样去处理字符串。
一,用临时表作为数组
复制代码 代码如下:

create function f_split(@c varchar(2000),@split varchar(2))
returns @t table(col varchar(20))
as
begin

while(charindex(@split,@c)<>0)
begin
insert @t(col) values (substring(@c,1,charindex(@split,@c)-1))
set @c = stuff(@c,1,charindex(@split,@c),'')
end
insert @t(col) values (@c)
return
end
go

select * from dbo.f_split('dfkd,dfdkdf,dfdkf,dffjk',',')

drop function f_split
col
--------------------
dfkd
dfdkdf
dfdkf
dffjk

(所影响的行数为 4 行)


二、按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。
复制代码 代码如下:

CREATE function Get_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

调用示例:select dbo.Get_StrArrayLength('78,1,2,3',',')
返回值:4

三、按指定符号分割字符串,返回分割后指定索引的第几个元素,象数组一样方便
复制代码 代码如下:

CREATE function Get_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
--这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。

return substring(@str,@start,@location-@start)
end

调用示例:select dbo.Get_StrArrayStrOfIndex('8,9,4',',',2)
返回值:9

三、结合上边两个函数,象数组一样遍历字符串中的元素
复制代码 代码如下:

declare @str varchar(50)
set @str='1,2,3,4,5'
declare @next int
set @next=1
while @next<=dbo.Get_StrArrayLength(@str,',')
begin
print dbo.Get_StrArrayStrOfIndex(@str,',',@next)
set @next=@next+1
end

调用结果:
1
2
3
4
5

相关文章

  • SQL server 随机数函数

    SQL server 随机数函数

    在SQL server中,有个随机函数rand(),有不少新手可能不知道存在这个函数,现在我就把这个函数的一些随机数生成技巧写出来,这是面向菜鸟的,老鸟请不要拍砖呀,我的头还不够硬
    2009-07-07
  • Sql注入工具_动力节点Java学院整理

    Sql注入工具_动力节点Java学院整理

    这篇文章主要为大家详细介绍了Sql注入工具的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • 关于SQL Server数据库中的用户权限和角色管理功能实现

    关于SQL Server数据库中的用户权限和角色管理功能实现

    在本文中,我们介绍了在SQL Server中创建用户、分配权限和管理角色的基础知识,请记住定期审查和更新用户权限,以符合您组织的安全政策和数据访问要求,这篇文章主要介绍了关于SQL Server数据库中的用户权限和角色管理,需要的朋友可以参考下
    2024-03-03
  • SQL 将一列拆分成多列的实现示例

    SQL 将一列拆分成多列的实现示例

    在SQL中,有时需要将一列数据按照特定的符号进行分割,分成多个列,本文就来介绍一下SQL 将一列拆分成多列的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • 浅谈一次与sql注入 & webshell 的美丽“邂逅”

    浅谈一次与sql注入 & webshell 的美丽“邂逅”

    这篇文章主要介绍了浅谈一次与sql注入 & webshell 的美丽“邂逅”,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • SQLServer导出sql文件/表架构和数据操作步骤

    SQLServer导出sql文件/表架构和数据操作步骤

    只导出了数据库的sql脚本,而表里的数据依然没有导出来,接下来将为你解决这个问题,感兴趣的看下教程哈
    2013-03-03
  • SqlServer公用表表达式(CTE)的具体使用

    SqlServer公用表表达式(CTE)的具体使用

    CTE是一种临时命名的结果集,,它在执行查询时存在,并且只在该查询执行期间有效,本文主要介绍了SqlServer公用表表达式的具体使用,感兴趣的可以了解一下
    2024-08-08
  • Sqlserver中char,nchar,varchar与Nvarchar的区别分析

    Sqlserver中char,nchar,varchar与Nvarchar的区别分析

    Sqlserver中char,nchar,varchar与Nvarchar的区别分析,使用sqlserver的朋友可以参考下。
    2011-08-08
  • VS自带的SQL server修改密码并连接使用

    VS自带的SQL server修改密码并连接使用

    本文主要介绍了VS自带的SQL server修改密码并连接使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • SQL Server的复制功能

    SQL Server的复制功能

    SQL Server的复制功能微软本身主要是用来发布及共享报表的。
    2009-05-05

最新评论