码迷,mamicode.com
首页 > 数据库 > 详细

SQL截取字符串分隔符中间部门的办法

时间:2017-10-14 16:44:08      阅读:302      评论:0      收藏:0      [点我收藏+]

标签:set   项目   char   字符串   长度   sql   取出   第一个   取字符串   

需求:实际项目中需要截取第2到第3个逗号中间部分的内容

方案:

declare @str nvarchar(50);
set @str=‘11,222,3333,44444‘;
select @str as ‘字符串‘
select len(@str) as ‘字符长度‘
select charindex(‘,‘,@str,1) as ‘第一个逗号的索引值‘
select LEFT(@str,charindex(‘,‘,@str,1)-1) as ‘第一个值‘
select SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)) as ‘从第一逗号开始截取出后面的字符串‘
select LEFT(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),CHARINDEX(‘,‘,SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),1)-1) as ‘中间的值‘
select SUBSTRING(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),charindex(‘,‘,SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),1)+1,len(@str)) as ‘最后面的值‘ --从第二个逗号开始截取出其后的字符串
select LEFT(
SUBSTRING(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),charindex(‘,‘,SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),1)+1,len(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str))))
,CHARINDEX(‘,‘,SUBSTRING(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),charindex(‘,‘,SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)),1)+1,len(SUBSTRING(@str,charindex(‘,‘,@str,1)+1,len(@str)))),1)-1
) as ‘第二中间的值‘

SQL截取字符串分隔符中间部门的办法

标签:set   项目   char   字符串   长度   sql   取出   第一个   取字符串   

原文地址:http://www.cnblogs.com/johsan/p/7667288.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!