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

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 代码 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
目录
相关文章
|
2月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
|
2月前
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
120 1
|
2月前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
2月前
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
118 1
|
2月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第17天】SQL Server 存储过程是预编译的 SQL 语句集,存于数据库中,可重复调用。它能提高性能、增强安全性和可维护性,但也有可移植性差、开发调试复杂及可能影响数据库性能等缺点。使用时需权衡利弊。
|
2月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
2月前
|
SQL 数据库 索引
SQL中COUNT函数结合条件使用的技巧与方法
在SQL查询中,COUNT函数是一个非常常用的聚合函数,用于计算表中满足特定条件的记录数
|
2月前
|
存储 SQL 数据库
SQL Server 临时存储过程及示例
SQL Server 临时存储过程及示例
60 3
|
2月前
|
SQL 关系型数据库 MySQL
SQL日期函数
SQL日期函数
|
3月前
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)