在SQL SERVER中实现Split功能的函数,并在存储过程中使用

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: 代码 CREATE FUNCTION dbo.SplitString(          @Expression NVARCHAR(4000), --要拆分的字符串          @Delimiter NVARCHAR(100), --拆分符号          @n INT --要得...
img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
CREATE   FUNCTION  dbo.SplitString
(
          
@Expression   NVARCHAR ( 4000 ),  -- 要拆分的字符串
           @Delimiter   NVARCHAR ( 100 ),  -- 拆分符号
           @n   INT   -- 要得到已拆分的返回字符串位置
)
RETURNS   NVARCHAR ( 4000 )
AS
BEGIN
DECLARE   @p   INT
SET   @p   =   CharIndex ( @Delimiter , @Expression )
IF   @p   >   0
          
BEGIN
          
SET   @p   =   @p   +   Len ( @Delimiter -   1
          
END
DECLARE   @i   INT
SET   @i   =   1
WHILE   @i   <   @n
          
BEGIN
          
SET   @i   =   @i   +   1
          
SET   @Expression   =   SubString ( @Expression @p   +   1 , Len ( @Expression -   @p  )
          
SET   @p   =   CharIndex ( @Delimiter , @Expression )
          
IF   @p   >   0
                    
BEGIN  
                    
SET   @p   =   @p   +   Len ( @Delimiter -   1
                    
END
          
ELSE
                    
BEGIN
                    
BREAK
                    
END
END

DECLARE   @s   NVARCHAR ( 1000 )
IF   @p   =   0   AND   @i   =   @n
          
BEGIN
          
SET   @s   =   @Expression
          
END
ELSE
          
IF   @i   =   @n
          
BEGIN
          
SET   @s   =   SubString ( @Expression 1 , @p   -   Len ( @Delimiter ))
          
END
RETURN   @s
END

使用方法:

img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
DECLARE   @string   NVARCHAR ( 50 )
SET   @string    =   ' 在|SQL SERVER|中实现Split|功能的|函数| '
DECLARE   @split   NVARCHAR ( 4 )
SET   @split   =   ' | '
SELECT  dbo.SplitString ( @string @split 1 )    --
SELECT  dbo.SplitString ( @string @split 2 )    -- SQL SERVER
SELECT  dbo.SplitString ( @string @split 3 )    -- 中实现Split
SELECT  dbo.SplitString ( @string @split 4 )    -- 功能的
SELECT  dbo.SplitString ( @string @split 5 )    -- 函数
SELECT  dbo.SplitString ( @string @split 6 )    -- null

 

 

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
4天前
|
SQL API 流计算
实时计算 Flink版产品使用合集之在Mac M1下的Docker环境中开启SQL Server代理的操作步骤是什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
18 1
|
3天前
|
SQL 数据处理 API
实时计算 Flink版产品使用合集之遇到SQL Server锁表问题如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
9 0
|
4天前
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用合集之当 SQL Server 源数据库中的数据更新后,CDC 吐出的操作(op)是怎样的
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
15 0
|
6天前
|
存储 数据库
sqlserver------数据库的存储过程(练习)
sqlserver------数据库的存储过程(练习)
8 1
|
6天前
|
SQL XML Linux
SQL Server的版本
【5月更文挑战第14天】SQL Server的版本
20 3
|
6天前
|
SQL 关系型数据库 数据管理
Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
【5月更文挑战第14天】Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统
16 2
|
6天前
|
SQL 存储 数据库连接
LabVIEW与SQL Server 2919 Express通讯
LabVIEW与SQL Server 2919 Express通讯
|
SQL 存储 数据库
SQL Server函数与存储过程 计算时间
SQL Server函数与存储过程 计算时间 一、通过一个开始时间、结束时间计算出一个工作日天数(不包含工作日与节假日);   1、函数 --创建函数,参数 @bengrq 开始时间,@endrq 结束时间 create function [dbo].
1732 0
|
SQL 存储 Perl
PL/SQL函数和存储过程
前言 活到老,学到老。 基本概念 --ORACLE 提供可以把PL/SQL 程序存储在数据库中,并可以在任何地方来运行它。这样就叫存储过程或函数。过程和函数统称为PL/SQL子程序,他们是被命名的PL/SQL块,均存储在数据库中,并通过输入、输出参数或输入/输出参数与其调用者交换信息。
1369 0