实例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等这些函数的组合就可以完美的实现字符串分切了哦。
