MySQL 字符串截取函数 SUBSTRING_INDEX

例子:

select
  SUBSTRING_INDEX(thumbnail,'/',-1) as file_name,
  thumbnail,
  SUBSTRING_INDEX(thumbnail,'.',-1) as suffix,
from tb_article where thumbnail != '';


介绍:

这里用到 MySQL 的 SUBSTRING_INDEX(str,delim,count) 函数,LENGTH(str) 函数,REPLACE(str,from_str,to_str) 函数,和数据库的一张辅助表help_topic(这张表在默认的mysql库里)。


SUBSTRING_INDEX(str,delim,count) 函数

参数:

str: 要分割的字符串

delim: 分割符(比如逗号,和点.)

count: 计数(分割到第几个),正数表示从左向右数,负数表示从右向左数


举例:

SELECT SUBSTRING_INDEX('www.baidu.com','.',1); -- 得到www
SELECT SUBSTRING_INDEX('www.baidu.com','.',2); -- 得到www.baidu
SELECT SUBSTRING_INDEX('www.baidu.com','.',-1); -- 得到com
SELECT SUBSTRING_INDEX('www.baidu.com','.',-2); -- 得到baidu.com

想要得到中间的baidu怎么办?这个要取两次才能得到的,第一次从右向左取,如上例子得到baidu.com,第二次将第一次的结果从左向右取,即可得到中间的字符baidu。

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('www.baidu.com','.',-2),'.',1); -- 得到baidu


有了这个函数的帮助,还需要确定什么呢?需要确定,当前要分割的位置。

如何来获取当前要分割的位置呢?可以先获取总共能拆分成多少个字符串:

SELECT LENGTH('192.168.211.35'); -- 得到长度是14


LENGTH(str)函数

LENGTH(str) – MYSQL的LENGTH(str)函数,统计字符串的长度


REPLACE(str,from_str,to_str)函数

REPLACE(str,from_str,to_str) – MYSQL的REPLACE(str,from_str,to_str)函数,意思是替换字符串,用to_str替换from_str得到最终的str


参数:

str:最终得到的字符串

from_str: 旧的字符(被替换的字符)

to_str: 新的字符


结果就是用新的字符替换旧的字符,得到的最终的字符串

SELECT REPLACE('192.168.211.35','.',''); -- 得到19216821135
SELECT LENGTH(REPLACE('192.168.211.35','.','')); -- 得到长度是11

最终呢,SELECT LENGTH('192.168.211.35') - LENGTH(REPLACE('192.168.211.35', ',', '')) + 1; -- 得到长度是4

那么其实我们想要的就是遍历前三个,分别获取当前位置的字符串:

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('192.168.211.35',',', index), ',', -1)


修改时间 2022-11-27

真诚赞赏,手留余香
赞赏
CSS
CSS 滚动条样式修改
2022-11-04
前端,HTML
p 标签里面不能嵌套块级元素
2022-11-05
ngtwewy
随机推荐
macOS 生成 icns 图标
如何使用命令修改 MySQL 数据库名称
Debian11 安装笔记3:安装 MySQL 5.7
支持 Selector API 的 HTML 解析器 node-html-parser
Linux 中 top 命令的 Load Average 含义
Node.js MySQL 连接池和事务
Linux apt 命令
如何调整 iconfont 图标的位置和基线
WordPress 获取当前主题文件夹的路径
Node.js 使用 Jest 做单元测试

微信联系我

夜间模式切换
回到顶部