MySQL 字符串操作详解和案例示范

2024-09-06 10:44

本文主要是介绍MySQL 字符串操作详解和案例示范,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL 字符串操作详解

MySQL 提供了丰富的字符串操作函数,能够对这些字符串进行截取、定位、替换等操作。本文将详细讲解 MySQL 中的字符串操作函数,包括 SUBSTRING()SUBSTR()LEFT()RIGHT()LOCATE()POSITION()FIND_IN_SET()ELT()INSERT()REPLACE(),并分析它们的区别和用法。

一、SUBSTRING()SUBSTR()

1. SUBSTRING() 函数

SUBSTRING() 函数用于从字符串中截取指定的子字符串。

语法:
SUBSTRING(str, pos, len);
  • str:要截取的字符串。
  • pos:截取的起始位置,正数表示从左往右,负数表示从右往左。
  • len(可选):截取的长度。
示例:

从订单编号 'ORD123456789' 中截取前 3 个字符:

SELECT SUBSTRING('ORD123456789', 1, 3) AS result;

输出:

+--------+
| result |
+--------+
| ORD    |
+--------+

从字符串 '123456789' 中截取最后 4 个字符:

SELECT SUBSTRING('123456789', -4) AS result;

输出:

+--------+
| result |
+--------+
| 6789   |
+--------+

2. SUBSTR() 函数

SUBSTR()SUBSTRING() 的别名,两者的用法和功能完全相同。我们可以互换使用。

示例:
SELECT SUBSTR('ORD123456789', 1, 3) AS result;

二、LEFT()RIGHT()

LEFT()RIGHT() 用于从字符串的左侧或右侧截取指定长度的子字符串。

1. LEFT() 函数

LEFT() 用于从字符串的左边截取指定长度的子字符串。

语法:
LEFT(str, len);
  • str:要截取的字符串。
  • len:截取的长度。
示例:

从订单编号 'ORD123456789' 中截取前 3 个字符:

SELECT LEFT('ORD123456789', 3) AS result;

输出:

+--------+
| result |
+--------+
| ORD    |
+--------+

2. RIGHT() 函数

RIGHT() 用于从字符串的右边截取指定长度的子字符串。

语法:
RIGHT(str, len);
  • str:要截取的字符串。
  • len:截取的长度。
示例:

从订单编号 'ORD123456789' 中截取后 3 个字符:

SELECT RIGHT('ORD123456789', 3) AS result;

输出:

+--------+
| result |
+--------+
| 789    |
+--------+

三、LOCATE()POSITION()

LOCATE()POSITION() 用于查找子字符串在字符串中的位置。

1. LOCATE() 函数

LOCATE() 用于返回子字符串在字符串中的第一次出现的位置。

语法:
LOCATE(substr, str, pos);
  • substr:要查找的子字符串。
  • str:要查找的字符串。
  • pos(可选):从字符串的第 pos 个字符开始查找。
示例:

查找 '123456789' 中子字符串 '456' 的位置:

SELECT LOCATE('456', '123456789') AS result;

输出:

+--------+
| result |
+--------+
| 4      |
+--------+

2. POSITION() 函数

POSITION()LOCATE() 的别名,通常与 IN 关键字一起使用。

语法:
POSITION(substr IN str);
示例:
SELECT POSITION('456' IN '123456789') AS result;

输出与 LOCATE() 相同。

四、FIND_IN_SET()

FIND_IN_SET() 函数用于查找一个字符串在以逗号分隔的字符串列表中的位置。

语法:
FIND_IN_SET(str, strlist);
  • str:要查找的字符串。
  • strlist:以逗号分隔的字符串列表。
示例:

查找 'orange' 在字符串列表 'apple,banana,orange' 中的位置:

SELECT FIND_IN_SET('orange', 'apple,banana,orange') AS result;

输出:

+--------+
| result |
+--------+
| 3      |
+--------+

五、ELT()

ELT() 函数返回逗号分隔的字符串列表中第 N 个字符串。

语法:
ELT(N, str1, str2, ...);
  • N:指定要返回的字符串的位置。
示例:

获取第 2 个字符串 'banana'

SELECT ELT(2, 'apple', 'banana', 'orange') AS result;

输出:

+--------+
| result |
+--------+
| banana |
+--------+

六、INSERT()

INSERT() 函数用于将一个字符串插入到另一个字符串中的指定位置。

语法:
INSERT(str, pos, len, newstr);
  • str:原始字符串。
  • pos:插入开始的位置。
  • len:要替换的字符数。
  • newstr:要插入的字符串。
示例:

'ABC' 插入到字符串 '123456789' 的第 4 个字符位置,替换 3 个字符:

SELECT INSERT('123456789', 4, 3, 'ABC') AS result;

输出:

+-----------+
| result    |
+-----------+
| 123ABC789 |
+-----------+

七、REPLACE()

REPLACE() 函数用于将字符串中的所有指定子字符串替换为另一个子字符串。

语法:
REPLACE(str, from_str, to_str);
  • str:要进行替换的字符串。
  • from_str:要被替换的子字符串。
  • to_str:新的子字符串。
示例:

'123456789' 中的所有 '456' 替换为 'ABC'

SELECT REPLACE('123456789', '456', 'ABC') AS result;

输出:

+-----------+
| result    |
+-----------+
| 123ABC789 |
+-----------+

这篇关于MySQL 字符串操作详解和案例示范的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Linux内核之内核裁剪详解

《Linux内核之内核裁剪详解》Linux内核裁剪是通过移除不必要的功能和模块,调整配置参数来优化内核,以满足特定需求,裁剪的方法包括使用配置选项、模块化设计和优化配置参数,图形裁剪工具如makeme... 目录简介一、 裁剪的原因二、裁剪的方法三、图形裁剪工具四、操作说明五、make menuconfig

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage