欢迎光临
个人知识库,ERP、IT知识分享和应用

sql语句,如何截取指定字段某一个字符出现后的字符串吗?

sql语句,能够截取指定字符串后面的一个字符串吗?

如下图:

dasf.sdf

dergre.adsf.lfs

ljjdf.ljfjl

想要得到第一个.后面的字符串内容

sdf

adsf.lfs

ljfjl

 

SQL语句写法如下,str为字段名称:

select id, substring(str,charindex(‘,’,str)+1,len(str)-charindex(‘,’,str)) from test;

如果中间间隔为-,则sql语句为

select id, substring(str,charindex(‘-‘,str)+1,len(str)-charindex(‘-‘,str)) from test;

实测:

取第一个 * 号后面 3位数

SELECT FSPECIFICATION,
SUBSTRING(FSPECIFICATION,CHARINDEX(‘*’,FSPECIFICATION)+1,3) AS fsp2    –使用substring函数参数,取3位数
FROM #tempruku20
取第一个 *号后面所有字符
SELECT FSPECIFICATION,
SUBSTRING(FSPECIFICATION,CHARINDEX(‘*’,FSPECIFICATION)+1,LEN(FSPECIFICATION)-CHARINDEX(‘*’,FSPECIFICATION)) AS fsp2
FROM #tempruku20
SQL中字符串截取函数(SUBSTRING)

1、left(name,4)截取左边的4个字符

列:

SELECT LEFT(201809,4) 年

结果:2018

2、right(name,2)截取右边的2个字符

SELECT RIGHT(201809,2) 月份

结果:09

3、SUBSTRING(name,5,3) 截取name这个字段 从第五个字符开始 只截取之后的3个字符

SELECT SUBSTRING('成都融资事业部',5,3)

结果:事业部

4、SUBSTRING(name,3) 截取name这个字段 从第三个字符开始,之后的所有个字符

SELECT SUBSTRING('成都融资事业部',3)

结果:融资事业部

5、SUBSTRING(name, -4) 截取name这个字段的第 4 个字符位置(倒数)开始取,直到结束

SELECT SUBSTRING('成都融资事业部',-4)

结果:资事业部

6、SUBSTRING(name, -4,2) 截取name这个字段的第 4 个字符位置(倒数)开始取,只截取之后的2个字符

SELECT SUBSTRING('成都融资事业部',-4,2)

结果:资事

注意:我们注意到在函数 substring(str,pos, len)中, pos 可以是负值,但 len 不能取负值。

7、substring_index(‘www.baidu.com’, ‘.’, 2) 截取第二个 ‘.’ 之前的所有字符

SELECT substring_index('www.baidu.com', '.', 2)

结果:www.baidu

8、substring_index(‘www.baidu.com’, ‘.’, -2) 截取第二个 ‘.’ (倒数)之后的所有字符

SELECT substring_index('www.baidu.com', '.', -2)

结果:baidu.com

9、SUBSTR(name, 1, CHAR_LENGTH(name)-3) 截取name字段,取除name字段后三位的所有字符

SELECT SUBSTR('成都融资事业部', 1, CHAR_LENGTH('成都融资事业部')-3)

结果:成都融资

 CHARINDEX作用

写SQL语句我们经常需要判断一个字符串中是否包含另一个字符串,但是SQL SERVER中并没有像C#提供了Contains函数,不过SQL SERVER中提供了一个叫CHAEINDX的函数,顾名思义就是找到字符(char)的位置(index),既然能够知道所在的位置,当然就可以判断是否包含在其中了。

通过CHARINDEX如果能够找到对应的字符串,则返回该字符串位置,否则返回0。

基本语法如下:

CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ] )

expressionToFind :目标字符串,就是想要找到的字符串,最大长度为8000 。

expressionToSearch :用于被查找的字符串。

start_location:开始查找的位置,为空时默认从第一位开始查找。

 

CHAEINDEX示例

1.简单用法

select charindex(‘test’,’this Test is Test’)

查询结果:

2.增加开始位置

select charindex(‘test’,’this Test is Test’,7)

查询结果:

3.大小写敏感

select charindex(‘test’,’this Test is Test’COLLATE Latin1_General_CS_AS)

查询结果:

返回结果为0???,不要怀疑你的眼睛,因为大小写敏感,找不到test所以返回的就是0,默认情况下, SQL SERVER是大小不敏感的,所以我们简单示例中返回结果不为0,但是有些时候我们需要特意去区分大小写,因此专门SQL SERVE提供了特殊的关键字用于查询时区分大小写,其中CS为Case-Sensitve的缩写。

4.大小写不敏感

select charindex(‘Test’,’this Test is Test’COLLATE Latin1_General_CI_AS)

查询结果:

我们也可以这样说明是大小写不敏感,其中CI是Case-InSensitve的缩写,即大小写不敏感,当然我们没必要多此一举。

 

PATINDEX

和CHARINDEX类似,PATINDEX也可以用来判断一个字符串中是否包含另一个字符串,两种的差异在于,前者是全匹配,后者支持模糊匹配。

1.简单示例

select PATINDEX(‘%ter%’,’interesting data’)

查询结果:

2.简单示例2

select PATINDEX(‘%t_ng%’,’interesting data’)

查询结果:

 

PATINDEX也允许支持大小写敏感,做法和CHARINDEX一样,此处不再累述。

未经允许不得转载:Blog.XiaoMing.Xyz » sql语句,如何截取指定字段某一个字符出现后的字符串吗?
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址