sqlserver中字符串根据某个字符进行截取

**字符串:**11-22-333-4444-55-666

**截取后的内容:**11、22、333、4444、55、666

注:可自定义一张临时表用于存放截取的内容

sql 复制代码
DECLARE @str NVARCHAR(50)='11-22-333-4444-55-666'  --字符串
DECLARE @custr NVARCHAR(5)='-'   --截取字符
DECLARE @length INT=LEN(@str)    --总长度
DECLARE @count INT=(@length - LEN(REPLACE(@str, @custr, ''))) / LEN(@custr) --截取字符总个数
DECLARE @i INT=0
DECLARE @j INT=0
DECLARE @e INT=0
DECLARE @newstr NVARCHAR(MAX)=''  --新字符串
DECLARE @restr NVARCHAR(max)=''   --返回字符


WHILE(@i<=@count)
BEGIN 
	--截取字符串
	SET @newstr=RIGHT(@str,@length-@j)

	SET @e=CHARINDEX(@custr,@newstr)

	IF @e>0
	SET @restr=SUBSTRING(@newstr,0,@e)
	ELSE 
	SET @restr=SUBSTRING(@newstr,0,LEN(@newstr))

	SELECT @restr

	SET @j=@j+LEN(@restr)+1

	SET @i=@i+1
END 
相关推荐
布丁椰奶冻19 小时前
【SQL Server数据库】数据库完整性实验
数据库·sql·sqlserver
泷泷_1 天前
SQL注入实战
数据库·sql·sqlserver·sql注入
Mercury_@224 天前
sqlserver开启CDC
数据库·sqlserver
zxrhhm5 天前
SQLServer 表值构造函数 (Transact-SQL)
数据库·sqlserver
布丁椰奶冻5 天前
【SQL Server数据库】视图的使用
java·数据库·sql·sqlserver
OptimizationMaster6 天前
【SQL Server点滴积累】为数据库邮件功能设定全局配置
数据库·sql·sqlserver
屿小夏.6 天前
【Python】已解决:(SqlServer报错)SQL错误(208):对象名‘string_split’无效
python·sql·sqlserver
布丁椰奶冻8 天前
【SQL Server数据库】熟悉DBMS的基本操作及数据库的创建
数据库·sqlserver
布丁椰奶冻9 天前
【SQL Server数据库】关系模式与关系代数
数据库·sqlserver