在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
目录
相关文章
|
7天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(2)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
7天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(1)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
8天前
|
SQL DataWorks NoSQL
DataWorks产品使用合集之如何将SQL Server中的数据转存到MongoDB
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
1天前
|
SQL 弹性计算 API
云服务器 ECS产品使用问题之如何通过API调用阿里云服务器上SQL Server数据库中的数据
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
1天前
|
SQL 存储 关系型数据库
关系型数据库中的SQL Server
【6月更文挑战第11天】
29 3
|
5天前
|
存储 SQL 关系型数据库
MySQL存储过程和存储函数的使用
MySQL的存储过程和存储函数在功能和用法上有明显的区别。存储过程是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,通过指定名称和参数(如果有)来调用执行,可以返回多个值或结果集,但不直接返回值。而存储函数则是一个有返回值的特殊存储过程,它返回一个值或表对象,可以直接嵌入SQL语句中使用,如SELECT语句中。两者都是为了提高SQL代码的重用性和性能,但使用场景和方式有所不同。
129 4
|
7天前
|
存储 关系型数据库 MySQL
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(4)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
7天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(3)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
11天前
|
SQL 存储 关系型数据库
PolarDB产品使用合集之有的sql里面有自定义存储函数 如果想走列存有什么优化建议吗
PolarDB是阿里云推出的一种云原生数据库服务,专为云设计,提供兼容MySQL、PostgreSQL的高性能、低成本、弹性可扩展的数据库解决方案,可以有效地管理和优化PolarDB实例,确保数据库服务的稳定、高效运行。以下是使用PolarDB产品的一些建议和最佳实践合集。
|
12天前
|
SQL 存储 关系型数据库
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
22 0