SQL字符串分割解析

  常用以下三种:

  【1】substring( expression ,start , length );

  【2】CHARINDEX ( expression1 , expression2 [ , start_location ] ) ;

  【3】LEFT(expression,start);

  注意:

  (1)substring中:对于start,负数和0都是空,真正有意义的位置是从" 1 "开始。

  (2)CHARINDEX中:expression1是要到expression2中寻找的字符,start_location是CHARINDEX函数开始在expression2中找expression1的位置。

  (3)LEFT中:表示截取expression的start索引位置左侧的字符串(包括索引位置在内)。

 

  方法一:动态SQL法

DECLARE @s VARCHAR(50),@sql VARCHAR(300)
SET @s='1,2,3,4,5,6,7,8,9,10'
SET @sql='SELECT col='''+ REPLACE(@s,',',''' UNION ALL SELECT ''')+''''
PRINT @sql
EXEC (@sql)

  方法二:循环截取法

IF EXISTS (
    SELECT * FROM dbo.sysobjects
        WHERE id = OBJECT_ID(N'[dbo].[f_splitSTR]') AND xtype IN (N'FN', N'IF', N'TF')
)
DROP FUNCTION [dbo].[f_splitSTR];
GO

CREATE FUNCTION f_splitSTR(  
    @s VARCHAR(8000),   --待分拆的字符串  
    @split VARCHAR(10)    --数据分隔符  
)RETURNS @re TABLE(col VARCHAR(100))  
AS  
BEGIN  
    WHILE CHARINDEX(@split,@s)>0  
    BEGIN  
        INSERT @re VALUES(LEFT(@s,CHARINDEX(@split,@s)-1))
        --删除目标字符串从start开始length并插入指定字符串
        SET @s=STUFF(@s,1,CHARINDEX(@split,@s),'') 
        --Set @s = Substring(@s, CharIndex(@split,@s)+@splitle, 100) 
    END  
    INSERT @re VALUES(@s)  
    RETURN  
END
GO

  方法三:使用临时性分拆辅助表法

IF EXISTS (
    SELECT * FROM dbo.sysobjects
        WHERE id = OBJECT_ID(N'[dbo].[f_splitSTR]') AND xtype IN (N'FN', N'IF', N'TF')
)
DROP FUNCTION [dbo].[f_splitSTR];
GO

CREATE FUNCTION f_splitSTR(
    @s VARCHAR(8000),  --待分拆的字符串
    @split VARCHAR(10) --数据分隔符
)RETURNS @re TABLE(col VARCHAR(100))
AS
BEGIN
    --创建分拆处理的辅助表(用户定义函数中只能操作表变量)  
    DECLARE @t TABLE(ID INT IDENTITY,b BIT)
    INSERT @t(b) SELECT TOP 8000 0 FROM syscolumns va
    INSERT @re SELECT SUBSTRING(@s,ID,CHARINDEX(@split,@s+@split,ID)-ID)
           FROM @t WHERE ID<=LEN(@s) AND CHARINDEX(@split,@s+@split,ID)=ID
    RETURN
END
GO

  方法四:使用永久性分拆辅助表法

IF EXISTS (
    SELECT * FROM dbo.sysobjects
        WHERE id = OBJECT_ID(N'[dbo].[f_splitSTR]') AND xtype IN (N'FN', N'IF', N'TF')
)
DROP FUNCTION [dbo].[f_splitSTR];
GO
IF EXISTS (
    SELECT * FROM dbo.sysobjects 
        WHERE id = OBJECT_ID(N'[dbo].[tb_splitSTR]') and objectproperty(id,N'IsUserTable')=1
)  
DROP TABLE [dbo].[tb_splitSTR]
GO 

--字符串分拆辅助表
SELECT TOP 8000 ID=IDENTITY(int,1,1) INTO dbo.tb_splitSTR FROM syscolumns a
GO
--字符串分拆处理函数
CREATE FUNCTION f_splitSTR(
    @s varchar(8000),  --待分拆的字符串
    @split varchar(10)     --数据分隔符
)RETURNS TABLE
AS
RETURN(
 SELECT col=CAST(SUBSTRING(@s,ID,CHARINDEX(@split,@s+@split,ID)-ID) as varchar(100))
   FROM tb_splitSTR
   WHERE ID<=LEN(@s) AND CHARINDEX(@split,@s+@split,ID)=ID)
GO

  方法五:利用sql server2005的OUTER APPLY

IF EXISTS (
    SELECT * FROM dbo.sysobjects
        WHERE id = OBJECT_ID(N'[dbo].[f_splitSTR]') AND xtype IN (N'FN', N'IF', N'TF')
)
DROP FUNCTION [dbo].[f_splitSTR];
GO

CREATE FUNCTION [dbo].[f_splitSTR]
(
  @str VARCHAR(MAX) ,
  @split VARCHAR(10)
)
RETURNS TABLE
AS
RETURN
    ( SELECT    B.id
      FROM      ( SELECT    [value] = CONVERT(XML , '<v>' + REPLACE(@str , @split , '</v><v>')
                            + '</v>')
                ) A
      OUTER APPLY ( SELECT  id = N.v.value('.' , 'varchar(100)')
                    FROM    A.[value].nodes('/v') N ( v )
                  ) B
    )

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在SQL Server中,可以使用一些方法来根据字符串进行分割操作。 1. 使用内置函数:可以使用内置函数`STRING_SPLIT`来将字符串分割成多个部分。这个函数接受两个参数,第一个是要分割字符串,第二个是用于分割的分隔符。它返回一个表格,其中包含分割后的每个部分。例如,下面的代码将字符串"apple,banana,orange"按照逗号进行分割: ``` SELECT value FROM STRING_SPLIT('apple,banana,orange', ',') ``` 返回结果为三行的表格,每一行分别为"apple","banana"和"orange"。 2. 使用递归查询:可以使用递归查询来实现字符串分割。首先,使用递归查询将字符串按照指定的分隔符进行分割,并为每个部分添加一个行号。然后,通过一个主查询将每个部分合并到一个结果集中。以下是实现字符串分割的递归查询示例: ``` WITH RecursiveCTE AS ( SELECT 1 AS RowNumber, CAST('apple,banana,orange' AS varchar(max)) AS RemainingString UNION ALL SELECT RowNumber + 1, SUBSTRING(RemainingString, CHARINDEX(',', RemainingString) + 1, LEN(RemainingString)) AS RemainingString FROM RecursiveCTE WHERE CHARINDEX(',', RemainingString) > 0 ) SELECT RemainingString AS Part FROM RecursiveCTE WHERE RowNumber > 1 ``` 返回结果为三行的表格,每一行分别为"banana","orange"和 NULL。 这些是在SQL Server中基于字符串进行分割的两种常见方法。根据实际需求和具体情况,选择合适的方法来实现字符串分割。 ### 回答2: 在SQL Server中,可以使用多种方法来根据字符串进行分割。以下是几种常见的方法: 1. 使用内置函数:可以使用内置的字符串函数来分割字符串。例如,使用SUBSTRING函数和CHARINDEX函数可以提取字符串中的子串。可以使用循环和判断条件来遍历字符串并提取需要的部分。 2. 使用XML:可以使用XML的功能来将字符串转换为XML格式,并使用XML的查询语言来分割字符串。可以使用节点、属性或XPath表达式来提取需要的字符串片段。 3. 使用递归查询:可以使用递归查询的技术来分割字符串。可以编写一个递归函数或存储过程,通过递归的方式遍历字符串并按照指定的分隔符进行分割。 4. 使用字符串分割函数:SQL Server中有一些自定义的字符串分割函数可以使用。这些函数可以接受字符串和分隔符作为参数,并返回一个包含分割后子串的表格。 需要根据具体的需求和实际情况选择适合的方法。无论使用哪种方法,分割字符串都需要一定的编程技巧和逻辑处理能力。 ### 回答3: 在 SQL Server 中,可以使用字符串分割函数 `STRING_SPLIT` 将字符串拆分成多个子字符串。该函数的语法如下: ``` STRING_SPLIT (string, separator) ``` 其中,`string` 是要分割字符串,`separator` 是用于分隔子字符串的分隔符。 例如,我们有一个字符串 `'apple,banana,orange'`,并且需要将其分割为三个子字符串 `'apple'`、`'banana'` 和 `'orange'`,可以使用以下代码实现: ``` DECLARE @str VARCHAR(100) = 'apple,banana,orange' SELECT value FROM STRING_SPLIT(@str, ',') ``` 执行以上代码,会得到以下结果: ``` value ----- apple banana orange ``` 可以看到,字符串已经按照逗号分隔成了三个子字符串。这些子字符串可以用于后续的操作,比如存储到表中或者进行其他处理。 需要注意的是,`STRING_SPLIT` 函数只适用于 SQL Server 2016 及以上版本。如果使用的是早期版本的 SQL Server,可以使用其他方法实现字符串分割,比如自定义函数或使用 XML 解析等。 综上所述,SQL Server 可以使用 `STRING_SPLIT` 函数根据字符串分割,使得我们可以方便地处理包含分隔符的字符串

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值