【MySQL用法】mysql如何进行以,分割的字符串的拆分

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 【MySQL用法】mysql如何进行以,分割的字符串的拆分

1、需求

现有如下需求:需要将字符串(电脑IP)

192.168.211.35

拆分成

192

168

211

35

2、实现(sql语句)

SELECT
    SUBSTRING_INDEX( SUBSTRING_INDEX( t.ip, '.', h.help_topic_id + 1 ), '.', - 1 )
FROM
    test.test t
    JOIN mysql.help_topic h ON h.help_topic_id < ( LENGTH( t.ip ) - LENGTH( REPLACE ( t.ip, '.', '' )) + 1 );H( REPLACE ( t.ip, '.', '' )) + 1 );

 

3、原理分析

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

3.1、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

3.2、LENGTH(str)函数

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

3.3、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)

其中index就是我们要遍历的位置,所以为了遍历,我们需要一个关联一个辅助表来得到当前位置,最后的设计如下:

SELECT
    SUBSTRING_INDEX( SUBSTRING_INDEX( t.ip, '.', h.help_topic_id + 1 ), '.', - 1 )
FROM
    test.test t
    JOIN mysql.help_topic h ON h.help_topic_id < ( LENGTH( t.ip ) - LENGTH( REPLACE ( t.ip, '.', '' )) + 1 );

需求最终得以实现:

我的测试数据库里表的内容是:

完结!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
SQL 自然语言处理 关系型数据库
MySQL的match匹配多个字符串的语法
【8月更文挑战第27天】MySQL的match匹配多个字符串的语法
612 67
|
存储 SQL 关系型数据库
MySQL 大表拆分
【9月更文挑战第13天】在 MySQL 中,为解决大数据量导致的性能问题,常采用表拆分策略,主要包括水平拆分和垂直拆分。水平拆分按规则将大表拆成多个小表,如范围划分(按时间或 ID)和哈希划分(按字段哈希值)。垂直拆分则按字段相关性拆分,减少表宽度。拆分需注意数据迁移、应用改造、索引优化及分布式事务处理等问题。实施前应充分评估和测试。
1205 8
|
关系型数据库 MySQL 索引
mysql中EXISTS用法注意点
mysql中EXISTS用法注意点
|
8月前
|
关系型数据库 MySQL
MySQL字符串拼接方法全解析
本文介绍了四种常用的字符串处理函数及其用法。方法一:CONCAT,用于基础拼接,参数含NULL时返回NULL;方法二:CONCAT_WS,带分隔符拼接,自动忽略NULL值;方法三:GROUP_CONCAT,适用于分组拼接,支持去重、排序和自定义分隔符;方法四:算术运算符拼接,仅适用于数值类型,字符串会尝试转为数值处理。通过示例展示了各函数的特点与应用场景。
|
SQL 关系型数据库 MySQL
Mysql-常用函数及其用法总结
以上列举了MySQL中一些常用的函数及其用法。这些函数在日常的数据库操作中非常实用,能够简化数据查询和处理过程,提高开发效率。掌握这些函数的使用方法,可以更高效地处理和分析数据。
345 19
|
数据采集 关系型数据库 MySQL
MySQL常用函数:IF、SUM等用法
本文介绍了MySQL中常用的IF、SUM等函数及其用法,通过具体示例展示了如何利用这些函数进行条件判断、数值计算以及复杂查询。同时,文章还提到了CASE WHEN语句和其他常用函数,如COUNT、AVG、MAX/MIN等,强调了它们在数据统计分析、数据清洗和报表生成中的重要性。
|
存储 SQL 关系型数据库
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
MySQL如何进行分库分表、数据迁移?从相关概念、使用场景、拆分方式、分表字段选择、数据一致性校验等角度阐述MySQL数据库的分库分表方案。
2064 15
一篇文章搞懂MySQL的分库分表,从拆分场景、目标评估、拆分方案、不停机迁移、一致性补偿等方面详细阐述MySQL数据库的分库分表方案
|
存储 SQL 关系型数据库
mysql用法
mysql用法
208 4
|
存储 自然语言处理 关系型数据库
MySQL的match用法说明
MySQL的match用法说明
753 4
|
SQL 关系型数据库 MySQL
MySQL的用法
MySQL的用法
218 2

推荐镜像

更多