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 
相关推荐
曹牧1 天前
SQLServer:生僻字
数据库·sqlserver
哥本哈士奇2 天前
SQLServer RAG笔记4:从服务层到前端交互
sqlserver
天下财经热4 天前
普渡和擎朗的配送机器人哪家更有优势?2026年商用配送场景选型分析
sqlserver
其实防守也摸鱼4 天前
全新安装 SQL Server 并直接设置数据目录到 E 盘 完整步骤
数据库·sql·网络安全·sqlserver·教程·工具
杨云龙UP5 天前
SQL Server2022部署:Windows Server 2016下安装、SSMS配置、备份还原与1433端口放通全流程_20260508
运维·服务器·数据库·sql·sqlserver·2022
就叫飞六吧11 天前
docker快速启动sqlserver实例并自动测试shell脚本
docker·容器·sqlserver
雾岛听风69112 天前
Sql server
数据库·sql·sqlserver
满昕欢喜13 天前
回顾与总结
数据库·sqlserver
wenha15 天前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
~小先生~15 天前
sqlserver 外键、级联使用
数据库·sqlserver