您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

sqlserver中字符串切割函数总结

2025/1/22 12:31:51发布23次查看
本文章收藏了大量的在sqlserver中字符串切割函数,包括了自用自定义函数或sql带带的函数来操作,有需要了解的同学可参考一下
实例1
循环while一个个读取
 代码如下 复制代码
alter function [dbo].[split]
(   
    @array varchar(7000)
    ,@split char(1)
)
returns @t table(v varchar(100))
as
begin
    while(charindex(@split,@array)0)  
        begin  
          insert @t values(substring(@array,1,charindex(@split,@array)-1));
          set @array=stuff(@array,1,charindex(@split,@array),'');
        end  
      insert @t values(@array);
    return;
end;
实例2
带,号的利用charindex处理
 代码如下 复制代码
 create function dbo.f_str(
@str varchar(8000)
)returns @r table(id int identity(1, 1), value varchar(5000))
as
begin
/* function body */
declare @pos int
set @pos = charindex(',', @str)
while @pos > 0
begin
insert @r(value) values(left(@str, @pos - 1))
select
@str = stuff(@str, 1, @pos, ''),
@pos = charindex(',', @str)
end
if @str > ''
insert @r(value) values(@str)
return
end
select * from f_splitstr('中,国,人')
实例3
按指定符号分割字符串,返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。
 代码如下 复制代码
create 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 @location0
  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
实例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 @location0 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
sqlserver中的字符串截取函数
1.截取已知长度的函数
a.截取从字符串左边开始n个字符 declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select left(@s1,4)
------------------------------------
显示结果: http
b.截取从字符串右边开始n个字符(例如取字符www.111cn.net) declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select right(@s1,11)
------------------------------------
显示结果: www.111cn.net
c.截取字符串中任意位置及长度(例如取字符www) declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select substring(@s1,8,3)
------------------------------------
显示结果: www.111cn.net
以上例子皆是已知截取位置及长度,下面介绍未知位置的例子
2.截取未知位置的函数
a.截取指定字符串后的字符串(例如截取http://后面的字符串)
方法一: declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select substring(@s1,charindex('www',@s1)+1,len(@s1))
/*此处也可以这样写:select substring(@s1,charindex('//',@s1)+2,len(@s1))*/
------------------------------------
显示结果: www.111cn.net
需要注意:charindex函数搜索字符串时,不区分大小写,因此charindex('www',@s1)也可以写成charindex('www',@s1)
方法二:(与方法一类似) declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select substring(@s1,patindex('%www%',@s1)+1,len(@s1))
--此处也可以这样写:select substring(@s1,patindex('%//%',@s1)+2,len(@s1))
------------------------------------
显示结果: www.111cn.net 函数patindex与charindex区别在于:前者可以参数一些参数,增加查询的功能
方法三: declare @s1 varchar(100)
 代码如下 复制代码
select @s1='http://www.111cn.net'
select replace(@s1,'http://','')
------------------------------------
显示结果: www.111cn.net
利用字符替换函数replace,将除需要显示字符串外的字符替换为空
方法四:
 代码如下 复制代码
declare @s1 varchar(100)
select @s1='http://www.111cn.net'
select stuff(@s1,charindex('http://',@s1),len('http://'),'')
本文章后面的实例就是上面函数的分解一,一个个stuff,substring等这些函数的组合就可以完美的实现字符串分切了哦。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product