要视情况而定,不同的要求有不同的截取办法。
可分为从左往右截取,从右往左截取,从第几位截取,关键字截取。步骤如下。
具体步骤如下:
从左开始截取字符串
left(str, length)
例: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),
然后要截取每个逗号之前那部分。
MySQL里面可以截取字符串的方法还是很丰富的:
# 从左侧截取,截取指定长度left(str,len)
# 右侧
right(str,len)
# 从中间某个位置截取指定长度
MID(str,pos,len)
# 同上
SUBSTR(str FROM pos FOR len)
# 从某个位置开始之后所有的字符
SUBSTR(str,pos)
如果最后面是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 中间那段是取最后那个[任务数字]的,请收藏。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)