首页 数据库 mysql教程 sqlserver中字符串切割函数总结

sqlserver中字符串切割函数总结

Jun 07, 2016 pm 05:49 PM
sqlserver 字符串切割

本文章收藏了大量的在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;

ALTER FUNCTION [dbo].[Split]

(   
    @Array VARCHAR(7000)

    ,@Split CHAR(1)

)

RETURNS @T TABLE(v VARCHAR(100))
 代码如下 复制代码

 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('中,国,人')

 

AS

BEGIN

    WHILE(CHARINDEX(@Split,@Array)<>0)  

        BEGIN  

          INSERT @T VALUES(SUBSTRING(@Array,1,CHARINDEX(@Split,@Array)-1));
 代码如下 复制代码

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 @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


 

          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 @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  

实例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

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
 代码如下 复制代码
Select @S1='http://www.111cn.net'
Select Left(@S1,4)

  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
 代码如下 复制代码
Select @S1='http://www.111cn.net'
Select right(@S1,11)
  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,那默认为字符串后边有一个分隔符号。

 
 代码如下 复制代码
Select @S1='http://www.111cn.net'
Select SUBSTRING(@S1,8,3)
  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 @S1='http://www.111cn.net'
Select Substring(@S1,CHARINDEX('www',@S1) 1,Len(@S1))
/*此处也可以这样写:Select Substring(@S1,CHARINDEX('//',@S1) 2,Len(@S1))*/
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))
 代码如下 复制代码
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区别在于:前者可以参数一些参数,增加查询的功能

 代码如下 复制代码
Select @S1='http://www.111cn.net'
Select REPLACE(@S1,'http://','')
方法三: 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://'),'')
方法四:

 代码如下 复制代码
Declare @S1 varchar(100) Select @S1='http://www.111cn.net' Select STUFF(@S1,CHARINDEX('http://',@S1),Len('http://'),'')
本文章后面的实例就是上面函数的分解一,一个个stuff,substring等这些函数的组合就可以完美的实现字符串分切了哦。
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

​sqlserver怎么导入mdf文件 ​sqlserver怎么导入mdf文件 Apr 08, 2024 am 11:41 AM

导入步骤如下:将 MDF 文件复制到 SQL Server 的数据目录(通常为 C:\Program Files\Microsoft SQL Server\MSSQL\DATA)。在 SQL Server Management Studio(SSMS)中,打开数据库并选择“附加”。单击“添加”按钮,选择 MDF 文件。确认数据库名称,点击确定按钮即可。

sqlserver数据库中已存在名为的对象怎么解决 sqlserver数据库中已存在名为的对象怎么解决 Apr 05, 2024 pm 09:42 PM

对于 SQL Server 数据库中已存在同名对象,需要采取以下步骤:确认对象类型(表、视图、存储过程)。如果对象为空,可使用 IF NOT EXISTS 跳过创建。如果对象有数据,使用不同名称或修改结构。使用 DROP 删除现有对象(谨慎操作,建议备份)。检查架构更改,确保没有引用删除或重命名的对象。

怎么查看sqlserver端口号 怎么查看sqlserver端口号 Apr 05, 2024 pm 09:57 PM

要查看 SQL Server 端口号:打开 SSMS,连接到服务器。在对象资源管理器中找到服务器名称,右键单击它,然后选择“属性”。在“连接”选项卡中,查看“TCP 端口”字段。

sqlserver服务无法启动怎么办 sqlserver服务无法启动怎么办 Apr 05, 2024 pm 10:00 PM

当 SQL Server 服务无法启动时,可采取以下步骤解决:检查错误日志以确定根本原因。确保服务帐户具有启动服务的权限。检查依赖项服务是否正在运行。禁用防病毒软件。修复 SQL Server 安装。如果修复不起作用,重新安装 SQL Server。

sqlserver误删数据库怎么恢复 sqlserver误删数据库怎么恢复 Apr 05, 2024 pm 10:39 PM

若误删 SQL Server 数据库,可采取以下步骤恢复:停止数据库活动;备份日志文件;检查数据库日志;恢复选项:从备份恢复;从事务日志恢复;使用 DBCC CHECKDB;使用第三方工具。请定期备份数据库并启用事务日志以防止数据丢失。

sqlserver数据库在哪里 sqlserver数据库在哪里 Apr 05, 2024 pm 08:21 PM

SQL Server 数据库文件通常存储在以下默认位置:Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data可通过修改数据库文件路径设置来自定义数据库文件位置。

Java连接SqlServer错误如何解决 Java连接SqlServer错误如何解决 May 01, 2023 am 09:22 AM

问题发现这次使用的是SqlServer数据库,之前并没有使用过,但是问题不大,我按照需求文档的步骤连接好SqlServer之后,启动SpringBoot项目,发现了一个报错,如下:刚开始我以为是SqlServer连接问题呢,于是便去查看数据库,发现数据库一切正常,我首先第一时间问了我的同事,他们是否有这样的问题,发现他们并没有,于是我便开始了我最拿手的环节,面向百度编程。开始解决具体报错信息是这样,于是我便开始了百度报错:ERRORc.a.d.p.DruidDataSource$CreateCo

sqlserver安装失败怎么样删除干净 sqlserver安装失败怎么样删除干净 Apr 05, 2024 pm 11:27 PM

如果 SQL Server 安装失败,可通过以下步骤清理:卸载 SQL Server删除注册表项删除文件和文件夹重启计算机

See all articles