MSSQL中截取特定的字符串

 

上午遇到一个需求,需要在数据库中截取一个字符串的特定部分:

假设一个字符串是邮箱地址“hello@163.com”,最后取到的字符串应该是“hello”。

因为上面的这个需求,看了一下数据库中关于字符串函数这方面的知识,最终可以得到以下几种解决的方法:

一、用到的函数:substring(' ', , )、charindex(' ',' ')

select SUBSTRING('hello@163.com',1,charindex('@','hello@163.com')-1)

1.substring(字符串表达式,开始位置,长度 ):

从一个指定字符串的指定位置截取制定长度的字符;

第一个参数表示被截取的字符串;

第二个参数表示要在第一个参数中开始截取的位置;

第三个参数表示要截取的长度。

例如:select substring('abc123',1,2)    →返回ab

从字符串‘abc123’的第一个字符开始截取,共截取两个字符,最后得到‘ab’。

2.charindex(字符串表达式1,字符串表达式2[,整数表达式]):

在字符串2中查找字符串1,如果存在返回第一个匹配的位置,如果不存在返回0。如果字符串1和字符串2中有一个是null则返回null。

可以指定在字符串2中查找的起始位置。

例如:select charindex('ab','BCabTabD')    → 返回3

           select charindex('ab','BCabTabD',4)   →返回6

二、用到的函数:left(' ', )、charindex(' ',' ')

select LEFT('hello@163.com',charindex('@','hello@163.com')-1)

1.left(字符串表达式,整数表达式):

从字符串表达式的最左边开始截取整数表达式个字符。

例如:select left('abcdef',3)   →返回abc

 

数据库这方面的知识,学的时候感觉简单,也容易理解,但是当学过之后一段时间不用了就会想不起来,这也充分的说明了一个问题:知识的积累也是一个重复的过程!

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值