如果最后面是4为,那么你取值时,只要把你字符串截取到总长度-4就行了(此条件必须是长度为两位),附SQL:
成都创新互联公司是专业的绥阳网站建设公司,绥阳接单;提供网站设计、成都网站制作,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行绥阳网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
update test set Name=substring(Name,1,length(Name)-4);
如果后面是任意长度,那么你需要截取到最后一个“[”这里,可以用以下SQL:
SELECT replace(Name,
REVERSE(LEFT(REVERSE(Name),INSTR(REVERSE(Name),'[')))
,'') from test
中间那段是取最后那个[任务数字]的,请收藏。
使用MYSQL的SUBSTRING_INDEX函数实现你的功能,此函数的语法解释如下:
SUBSTRING_INDEX(str,delim,count)
返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。
mysql select SUBSTRING_INDEX('', '.', 2);
- ''
mysql select SUBSTRING_INDEX('', '.', -2);
- 'mysql.com'
该函数对多字节是可靠的。
如果你的字段名为xxx,值为201207|123|23.5|100|50|和20120703|19|212|||,要获取第3个内容23.5的函数是:
SUBSTRING_INDEX(SUBSTRING_INDEX(xxx,'|',3),'|',-1)
里面的函数获取第3个开始的所有内容,外面的函数获取里面函数结果的第1个内容
MySQL里面可以截取字符串的方法还是很丰富的:
# 从左侧截取,截取指定长度
left(str,len)
# 右侧
right(str,len)
# 从中间某个位置截取指定长度
MID(str,pos,len)
# 同上
SUBSTR(str FROM pos FOR len)
# 从某个位置开始之后所有的字符
SUBSTR(str,pos)