-
sql语句大全之SQL Server自定义字符串分割函数——
SQL Server自定义字符串分割函数——Split
我相信大部分人都碰到过,处理数据的时候,字段的值是以 ',' (逗号)分隔的形式,所以我也不能避免。
然后我才知道,sql 是没有类似于 C# 和 Javascript 这种分割字符串的方法。( Split )
所以我自己定义了一个 sql 函数(多声明表值函数),代码如下:
1 USE [Test] 2 GO 3 /****** Object: UserDefinedFunction [dbo].[Split] Script Date: 2017/4/14 23:04:08 ******/ 4 SET ANSI_NULLS ON 5 GO 6 SET QUOTED_IDENTIFIER ON 7 GO 8 CREATE FUNCTION [dbo].[Split](@separator VARCHAR(64)=',',@string NVARCHAR(max)) 9 RETURNS @ResultTab TABLE ( 10 Id INT , 11 Res NVARCHAR(500) 12 ) 13 AS 14 BEGIN 15 DECLARE @Num INT 16 17 IF(@string IS NOT NULL AND @string <> '' AND LEN(@string)>0) 18 BEGIN 19 IF(CHARINDEX(@separator,@string)>0) --判断要截取的字符是否存在 20 BEGIN 21 SET @Num=0 22 WHILE (CHARINDEX(@separator,@string)>0) --如果要截取的字符存在,就继续循环 23 BEGIN 24 SET @Num=@Num+1 25 26 INSERT INTO @ResultTab(Id,Res) --截取字符串,插入表变量 27 SELECT @Num,LEFT(@string,CHARINDEX(@separator,@string)-1) 28 29 --把已经截取并插入的字符串删除 30 SET @string=STUFF(@string,1,CHARINDEX(@separator,@string)-1+LEN(@separator),'') 31 END 32 33 --如果最后一个截取的字符串为空,那就不插入了 34 --例如:'123,456,789,' 这样的字符串最后剩下的就是空字符串了 35 IF(@string IS NOT NULL AND @string <> '') 36 BEGIN 37 INSERT INTO @ResultTab(Id,Res) 38 SELECT @Num+1,@string 39 END 40 END 41 ELSE 42 BEGIN 43 DELETE FROM @ResultTab 44 END 45 END 46 ELSE 47 BEGIN 48 DELETE FROM @ResultTab 49 END 50 RETURN 51 END
下面来调用一下试试效果:
1 --因为这个函数创建的时候默认为以 逗号 分割,所以只需要使用 default 关键字就可以了 2 select * from Split(default,'123,456,789') 3 4 select * from Split(default,'123,456,789,') 5 6 --下面试试其它字符分割 7 select * from Split('abc','11111abc22222abc33333') 8 9 select * from Split('abc','11111abc22222abc33333abc')
不足的地方就是不能直接作用于表,和不能同时支持多字符分割。
当然,如果多定义几个参数,也是勉强可以的,不过我想的是能够和 C# 那种可以传入一个分割字符的数组,不过貌似 sql 自定义函数的参数不支持 table 类型。
另外,如果有什么好的想法,可以探讨一下。多谢~
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式