
要视情况而定,不同的要求有不同的截取办法。
可分为从左往右截取,从右往左截取,从第几位截取,关键字截取。步骤如下。
具体步骤如下:
从左开始截取字符串
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(), right(), substring(),第一个是从左边开始截取,两个参数分别是字段和截取长度,第二正好相反,从右边截取,最后一个方法是指定区间,三个参数控制如果最后面是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条)