[sqlserver][sql]将一个字符串按照分隔符进行分割

SQL 函数 SplitIn 是用来将一个字符串 @c 按照分隔符 @split 进行分割,并将分割后的子字符串以表的形式返回。下面是对这个函数的中文解释:

  1. 函数 SplitIn 定义了两个参数:@c 是需要被分割的字符串,@split 是用于分割字符串的分隔符。

  2. 函数返回一个名为 @t 的表,表中有一个名为 col 的列,用于存储分割后的子字符串。

  3. 函数使用 while 循环来不断查找字符串 @c 中分隔符 @split 的位置。

  4. 在循环内部,它将分隔符前的子字符串插入到表 @t 中。

  5. 使用 stuff 函数来移除字符串 @c 中已经被处理的部分(从开始到分隔符)。

  6. 当字符串 @c 中不再包含分隔符时,循环结束。

  7. 循环结束后,将字符串 @c 中剩余的部分(不包含分隔符)插入到表 @t 中。

  8. 最后,函数返回表 @t

sql 复制代码
create  function  SplitIn(@c   varchar(2000),@split   varchar(2))   
returns   @t   table(col   varchar(20))   
as   
begin    
  while(charindex(@split,@c)<>0)   
    begin   
      insert   @t(col)   values   (substring(@c,1,charindex(@split,@c)-1))   
      set   @c   =   stuff(@c,1,charindex(@split,@c),'')   
    end   
  insert   @t(col)   values   (@c)   
  return   
end  

这个函数可以在 SQL Server 中使用,用于根据指定的分隔符将字符串分割成多个部分。以下是如何使用这个函数的一个示例:

sql 复制代码
DECLARE @MyString varchar(2000) = 'apple,banana,cherry';
DECLARE @Delimiter varchar(2) = ',';

DECLARE @Result TABLE (col varchar(20));

INSERT INTO @Result(col)
EXEC dbo.SplitIn @MyString, @Delimiter;

SELECT * FROM @Result;
相关推荐
m0_564264183 小时前
IDEA DEBUG调试时如何获取 MyBatis-Plus 动态拼接的 SQL?
java·数据库·spring boot·sql·mybatis·debug·mybatis-plus
隐语SecretFlow4 小时前
隐语SecreFlow SCQL 1.0.0b1 发布:更完善的 SQL 支持与更高效的隐私查询引擎
数据库·sql
悟能不能悟10 小时前
在service方法中已经catch异常,Transactional失效怎么办
java·数据库·sql
zimoyin10 小时前
解决导入的数据库中因为 sql_mode 不同 视图无法打开问题
数据库·sql
码界奇点11 小时前
Java 开发日记MySQL 与 Redis 双写一致性策略挑战与实战解析
java·redis·sql·mysql·java-ee
NineData12 小时前
NineData社区版 V4.6.0 正式发布!SQL 窗口新增4个数据源,新增支持OceanBase等多条数据复制和对比链路
数据库·sql·dba
那我掉的头发算什么13 小时前
【数据库】增删改查 高阶(超级详细)保姆级教学
java·数据库·数据仓库·sql·mysql·性能优化·数据库架构
雨夜赶路人13 小时前
SQL -- GROUP BY 基本语法
数据库·sql
迷了璐的航14 小时前
mybatis解决查询中使用group by时出现sql_mode=only_full_group_by
数据库·sql·mybatis
悟能不能悟16 小时前
mybatis的sql中,如果一个条件column=#{column},column的值为null时,会不会匹配出column is null 的记录
sql·tomcat·mybatis