SQL截取字段字符串的方法

set @str=‘WX15-53-H-53-99-15-335-23’;


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 '第2个-后面的值’

 

select SUBSTRING(SUBSTRING(@str,charindex('-',@str,2)+1,len(@str)),charindex('-',SUBSTRING(@str,charindex('-',@str,2)+1,len(@str)),2)+1,len(@str)) as '第2个-后面的值’

select SUBSTRING(SUBSTRING(@str,charindex('-',@str,6)+1,len(@str)),charindex('-',SUBSTRING(@str,charindex('-',@str,6)+1,len(@str)),6)+1,len(@str)) as '第5个-后面的值’

以此类推 取出的值为:15-335-23

 

select SUBSTRING('23*2*3',charindex('*','23*2*3')-2,2)

select charindex('*','223*332*3',1)

select LEFT('223*2*3',charindex('*','223*2*3',1)-1)
select LEFT('223*332*3',charindex('*','223*332*3',1)+1,charindex('*','223*332*3',1)-1)

declare @str varchar(50)
set @str='223*3325*3444'

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 '第2个-后面的值'

multiply
select b.goods,b.one_cat,b.number,b.Goods_unit_price,b.Goods_sum_price,b.dd_size,
convert(decimal(10,2),convert(decimal(10,2),LEFT(b.dd_size,charindex('*',b.dd_size,1)-1))*convert(decimal(10,2),LEFT(SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),CHARINDEX('*',SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),1)-1))*convert(decimal(10,2),SUBSTRING(SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),charindex('*',SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),1)+1,len(b.dd_size)))),
convert(decimal(10,2),LEFT(b.dd_size,charindex('*',b.dd_size,1)-1))
,convert(decimal(10,2),LEFT(SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),CHARINDEX('*',SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),1)-1))
,convert(decimal(10,2),SUBSTRING(SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),charindex('*',SUBSTRING(b.dd_size,charindex('*',b.dd_size,1)+1,len(b.dd_size)),1)+1,len(b.dd_size)))
from pmw_packInfo p left join pmw_billcode b on p.goodsID=b.goodsID

 

转载于:https://www.cnblogs.com/LuoEast/p/7171180.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值