MySQL 提供了丰富的字符串操作函数,能够对这些字符串进行截取、定位、替换等操作。本文将详细讲解 MySQL 中的字符串操作函数,包括 SUBSTRING()
、SUBSTR()
、LEFT()
、RIGHT()
、LOCATE()
、POSITION()
、FIND_IN_SET()
、ELT()
、INSERT()
和 REPLACE()
,并分析它们的区别和用法。
SUBSTRING()
和 SUBSTR()
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 |
+--------+
SUBSTR()
函数SUBSTR()
是 SUBSTRING()
的别名,两者的用法和功能完全相同。我们可以互换使用。
SELECT SUBSTR('ORD123456789', 1, 3) AS result;
LEFT()
和 RIGHT()
LEFT()
和 RIGHT()
用于从字符串的左侧或右侧截取指定长度的子字符串。
LEFT()
函数LEFT()
用于从字符串的左边截取指定长度的子字符串。
LEFT(str, len);
str
:要截取的字符串。len
:截取的长度。从订单编号 'ORD123456789'
中截取前 3 个字符:
SELECT LEFT('ORD123456789', 3) AS result;
输出:
+--------+
| result |
+--------+
| ORD |
+--------+
RIGHT()
函数RIGHT()
用于从字符串的右边截取指定长度的子字符串。
RIGHT(str, len);
str
:要截取的字符串。len
:截取的长度。从订单编号 'ORD123456789'
中截取后 3 个字符:
SELECT RIGHT('ORD123456789', 3) AS result;
输出:
+--------+
| result |
+--------+
| 789 |
+--------+
LOCATE()
和 POSITION()
LOCATE()
和 POSITION()
用于查找子字符串在字符串中的位置。
LOCATE()
函数LOCATE()
用于返回子字符串在字符串中的第一次出现的位置。
LOCATE(substr, str, pos);
substr
:要查找的子字符串。str
:要查找的字符串。pos
(可选):从字符串的第 pos
个字符开始查找。查找 '123456789'
中子字符串 '456'
的位置:
SELECT LOCATE('456', '123456789') AS result;
输出:
+--------+
| result |
+--------+
| 4 |
+--------+
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 |
+-----------+