mysql 字符串截取

mysql 字符串截取,第1张

使用MYSQL的SUBSTRING_INDEX函数实现你的功能,此函数的语法解释如下:

SUBSTRING_INDEX(str,delim,count)

返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。

mysql>select SUBSTRING_INDEX('www.mysql.com', '.', 2)

->'www.mysql'

mysql>select SUBSTRING_INDEX('www.mysql.com', '.', -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个内容

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

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

具体步骤如下:

从左开始截取字符串

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),

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

mysql>select @col

+---------------------------+

| @col |

+---------------------------+

| 2.1.3.14单独的3中文3中文1 |

+---------------------------+

1 row in set

mysql>select concat(substring_index(@col, ".", 3), ".", replace(@col, concat(substring_index(@col, ".", 3), "."), "")+0) as result

+----------+

| result |

+----------+

| 2.1.3.14 |

+----------+

1 row in set

你把第二句中的 @col 替换成你的列名就可以了,然后加上 from 表 成为一个完成的 sql 语句试试吧。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存