mysql的查询中怎么截取字符串?

mysql的查询中怎么截取字符串?,第1张

要视情况而定,不同的要求有不同的截取办法。

可分为从左往右截取,从右往左截取,从第几位截取,关键字截取。步骤如下。

具体步骤如下:

从左开始截取字符串

left(str, length)

说明:left(被截取字段,截取长度)

例:select left(content,200) as abstract from my_content_t

从右开始截取字符串

right(str, length)

说明:right(被截取字段,截取长度)

例:select right(content,200) as abstract from my_content_t

截取字符串

substring(str, pos)

substring(str, pos, length)

说明:substring(被截取字段,从第几位开始截取)

substring(被截取字段,从第几位开始截取,截取长度)

例:select substring(content,5) as abstract from my_content_t

select substring(content,5,200) as abstract from my_content_t

(注:如果位数是负数 如-5 则是从后倒数位数,到字符串结束或截取的长度)

按关键字截取字符串

substring_index(str,delim,count)

说明:substring_index(被截取字段,关键字,关键字出现的次数)

例:select substring_index(”blog.chinabyte.com”,”。”,2) as abstract from my_content_t

结果:blog.chinabyte

(注:如果关键字出现的次数是负数 如-2 则是从后倒数,到字符串结束)

结果:chinabyte.com

截取的字符串为15,151,152,16’,可以看作是ip吧(虽然这里指的不是iP),

然后要截取每个逗号之前那部分。

如果最后面是4为,那么你取值时,只要把你字符串截取到总长度-4就行了(此条件必须是长度为两位),附SQL:

update

test

set

Name=substring(Name,1,length(Name)-4)

如果后面是任意长度,那么你需要截取到最后一个“[”这里,可以用以下SQL:

SELECT

replace(Name,

REVERSE(LEFT(REVERSE(Name),INSTR(REVERSE(Name),'[')))

,'')

from

test

中间那段是取最后那个[任务数字]的,请收藏。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5897377.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存