MySQL 字符串截取函数及用法详解

2025-05-21 02:50

本文主要是介绍MySQL 字符串截取函数及用法详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST...

MySQL 字符串截取函数详解

在 MySQL 中,字符串截取是常见的操作,主要用于从字符串中提取特定部分。MySQL 提供了多种函数来实现这一功能,包括 LEFT()RIGHT()SUBSTRING()MID()SUBSTR()SUBSTRING_INDEX() 等。本文将详细介绍这些函数的用法,并通过示例进行说明。

LEFT(str, length):从左侧截取指定长度的字符

功能:从字符串 str 的左侧开始,截取 length 个字符。

语法

LEFT(str, length)

示例

SELECT LEFT('sqlstudy.com', 3);

结果

+-------------------------+
| LEFT('sqlstudy.com', 3) |
+-------------------------+
| sql |
+-------------------------+

解释:从 'sqlstudy.com' 的左侧开始,截取 3 个字符,结果为 'sql'

RIGHT(str, length):从右侧截取指定长度的字符

功能:从字符串 str 的右侧开始,截取 length 个字符。

语法

RIGHT(str, length)

示例

SELECT RIGHT('sqlstudy.com', 3);

结果

+--------------------------+
| RIGHT('sqlstudy.com', 3) |
+--------------------------+
| com |
+--------------------------+

解释:从 'sqlstudy.com' 的右侧开始,截取 3 个字符,结果为 'com'

SUBSTRING(str, pos) 或 SUBSTRING(str, pos, len):从指定位置开始截取

功能:从字符串 str 的第 pos 个字符开始,截取 len 个字符。pos 可以是正数或负数,正数表示从左侧开始,负数表示从右侧开始。

语法

SUBSTRING(str, pos)
SUBSTRING(str, pos, len)

示例

-- 从第 4 个字符开始,直到结束
SELECT SUBSTRING('sqlstudy.com', 4);
-- 从第 4 个字符开始,截取 2 个字符
SELECT SUBSTRING('sqlstudy.com', 4, 2);
-- 从倒数第 4 个字符开始,直到结束
SELECT SUBSTRING('sqlstudy.com', -4);
-- 从倒数第 4 个字符开始,截取 2 个字符
SELECT SUBSTRING('sqlstudy.com', -4, 2);

结果

+------------------------------+
| SUBSTRING('sqlstudy.com', 4) |
+------------------------------+
| study.com |
+------------------------------+

+---------------------------------+
| SUBSTRING('sqlstudy.com', 4, 2) |
+---------------------------------+
| st |
+---------------------------------+

+-------------------------------+
| SUBSTRING('sqlstudy.com', -4) |
+-------------------------------+
| .com |
+-------------------------------+

+----------------------------------+
| SUBSTRING('shttp://www.chinasem.cnqlstudy.com', -4, 2) |
+-------------http://www.chinasem.cn---------------------+
| .c |
+----------------------------------+

解释

  • SUBSTRING('sqlstudy.com', 4):从第 4 个字符开始,直到字符串结束,结果为 android'study.com'
  • SUBSTRING('sqlstudy.com', 4, 2):从第 4 个字符开始,截取 2 个字符,结果为 'st'
  • SUBSTRING('sqlstudy.com', -4):从倒数第 4 个字符开始,直到字符串结束,结果为 '.com'
  • SUBSTRING('sqlstudy.com', -4, 2):从倒数第 4 个字符开始,截取 2 个字符,结果为 '.c'

注意

len 必须为非负整数。若省略 len,则默认截取到字符串末尾。

pos 超出字符串长度或为 0,返回空字符串。例如:

SELECT SUBSTRING('abc', 0, 1);   -- 结果:空字符串
SELECT SUBSTRING('abc', 5, 1);   -- 结果:空字符串

SUBSTRING_INDEX(str, delim, count):根据分隔符截取字符串

功能:根据分隔符 delim,从字符串 str 中截取出第 count 次出现的分隔符前或后的子字符串。count 为正数时,从左侧开始计数;为负数时,从右侧开始计数。

语法

SUBSTRING_INDEX(str, delim, count)

示例

-- 截取第二个 '.' 之前的所有字符
SELECT SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', 2);
-- 截取倒数第二个 '.' 之后的所有字符
SELECT SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', -2);
-- 如果分隔符不存在,返回整个字符串
SELECT SUBSTRING_INDEX('www.sqlstudy.com.cn', '.coc', 1);

结果

+------------------------------------------------+
| SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', 2) |
+------------------------------------------------+
| www.sqlstudy |
+------------------------------------------------+

+-------------------------------------------------+
| SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', -2) |
+-------------------------------------------------+
| com.cn |
+-------------------------------------------------+

+---------------------------------------------------+
| SUBSTRING_INDEX('www.sqlstudy.com.cn', '.coc', 1) |
+---------------------------------------------------+
| www.sqlstudy.com.cn |
+---------------------------------------------------+

解释

  • SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', 2):返回第 2 次出现的 . 之前的所有字符,结果为 'www.sqlstudy'
  • SUBSTRING_INDEX('www.sqlstudy.com.cn', '.', -2):返回倒数第 2 次出现的 . 之后的所有字符,结果为 'com.cn'
  • SUBSTRING_INDEX('www.sqlstudy.com.cn', '.coc', 1):由于 .coc 不存在于字符串中,返回整个字符串 'www.sqlstudy.com.cn'

注意

count编程 超过分隔符实际出现的次数,返回整个字符串。例如:

SELECT SUBSTRING_INDEX('a.b.c.d', '.', 5);  -- 结果:'a.b.c.d'

MID(str, pos, len) 或 SUBSTR(str, pos, len):与 SUBSTRING 等价

功能:与 SUBSTRING 函数功能相同,用于从指定位置开始截取指定长度的子字符串。

语法

MID(str, pos, len)
SUBSTR(str, pos, len)

示例

-- 从第 4 个字符开始,截取 2 个字符
SELECT MID('sqlstudy.com', 4, 2);
-- 从倒数第 4 个字符开始,截取 2 个字符
SELECT SUBSTR('sqlstudy.com', -4, 2);

结果

+----------------------------------+
| MID('sqlstudy.com', 4, 2) |
+----------------------------------+
| st |
+----------------------------------+

+-----------------------------------+
| SUBSTR('sqlstudy.com', -4, 2) |
+-----------------------------------+
| .c |
+-----------------------------------+

解释

  • MID('sqlstudy.com', 4, 2)SUBSTRING('sqlstudy.com', 4, 2) 结果相同,均为 'st'
  • SUBSTR('sqlstudy.com', -4, 2)SUBSTRING('sqlstudy.com', -4, 2) 结果相同,均为 '.c'

多字节字符处理

MySQL 的字符串截取函数默认按字符(而非字节)处理,适用于多字节字符集(如 UTF-8)。例如:

SELECT LEFT('中文测试', 2);  -- 结果:'中文'
SELECT SUBSTRING('数据库', 2, 2);  -- 结果:'据库'

实际应用场景

场景 php1:提取邮箱的域名

SELECT 
  email,
  SUBSTRING_INDEX(email, '@', -1) AS domain
FROM users;

结果

+-------------------+-------------+
| email | domain |
+-------------------+-------------+
| user@example.com | example.com |
+-------------------+-------------+

场景 2:解析 URL 中的路径

SELECT 
  SUBSTRING_INDEX(SUBSTRING_INDEX(url, '//', -1), '/', 1) AS host
FROM website;

输入'https://www.sqlstudy.com/path'
输出'www.sqlstudy.com'

总结

函数功能概要核心区别
LEFT() / RIGHT()从左右侧截取固定长度方向固定,长度明确
SUBSTRING()灵活指定起始位置和长度支持正负位置,功能最全面
SUBSTRING_INDEX()基于分隔符截取适合处理结构化字符串(如路径)
MID() / SUBSTR()SUBSTRING 功能相同语法别名,可互换使用

掌握这些函数,可以高效处理字符串截取需求,提升数据处理的灵活性。

这篇关于MySQL 字符串截取函数及用法详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154698

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文