欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

mysql 字符串截取 部分串

shiping1 的头像

这里要注意 其开始位置 应该是1,而不是0

如果是负数 ,就是从最后倒过来数

函数: 
1、从左开始截取字符串 
left(str, length) 
说明:left(被截取字段,截取长度) 
例:select left(content,200) as abstract from my_content_t 
2、从右开始截取字符串 
right(str, length) 
说明:right(被截取字段,截取长度) 
例:select right(content,200) as abstract from my_content_t 
3、截取字符串 
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 则是从后倒数位数,到字符串结束或截取的长度) 

 记住 这里的pos位置是从1开始 而不是从0开始
4、按关键字截取字符串 
substring_index(str,delim,count) 
说明:substring_index(被截取字段,关键字,关键字出现的次数) 
例:select substring_index("blog.jb51.net" , "." , 2) as abstract from my_content_t 

  截取第二个 '.' 之前的所有字符。
结果:blog.jb51 
(注:如果关键字出现的次数是负数 如-2 则是从后倒数,到字符串结束   从最后倒过来数到第二个".",然后取第二个 '.' 之后的所有字符。 

如果在字符串中找不到 delim 参数指定的值,就返回整个字符串

函数简介:

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)

不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。

详情请查阅手册。

例子


 

取出列 ;取出的长度为它本来的长度-2
select substring(money_year,1,CHAR_LENGTH(money_year)-2) from dede_addon17;


更新列 ;使其长度为它本来的长度-2

update dede_addon17 set
money_year=substring(money_year,1,CHAR_LENGTH(money_year)-2);

 

来自http://www.jb51.net/article/27458.htm

普通分类: