MySQL常用的字符串函数举例

MySQL提供了许多常用的字符串函数,以下是其中一些常用的字符串函数和用法:

1、CONCAT

CONCAT函数用于连接两个或多个字符串。以下是一个示例:

SELECT CONCAT('Hello',' ','World')AS greeting;

输出:

+---------------+
| greeting |
+---------------+
| Hello World |
+---------------+

2、CONCAT_WS

CONCAT_WS函数用于连接两个或多个字符串,使用一个指定的分隔符。以下是一个示例:

SELECT CONCAT_WS(',','apple','banana','orange')AS fruits;

输出:

+------------------------+
| fruits |
+------------------------+
| apple,banana,orange |
+------------------------+

在这个例子中,我们将三个字符串’apple’、’banana’、’orange’使用逗号分隔符连接

3、LENGTH

LENGTH函数返回给定字符串的长度(字节数)。以下是一个示例:

SELECT LENGTH('Hello World')AS len;

输出:

+-----+
| len |
+-----+
|11|
+-----+

4、CHAR_LENGTH

在MySQL中,CHAR_LENGTH和LENGTH都是用于获取字符串长度的函数,但它们有一些区别。

CHAR_LENGTH函数返回字符串中字符的个数,而LENGTH函数返回字符串中字节数的个数。在大多数情况下,这两个函数返回的结果是相同的,因为一个字符通常只占用一个字节。但是,对于某些特殊字符,如UTF-8编码中的一些多字节字符,一个字符可能需要占用多个字节,这时候它们就会返回不同的结果。

以下是一个示例:

SELECT CHAR_LENGTH('Hello World')AS char_length, LENGTH('Hello World')AS length;

输出:

+-------------+--------+
| char_length | length |
+-------------+--------+
|11|11|
+-------------+--------+

在这个例子中,我们将字符串’Hello World’作为参数传递给CHAR_LENGTH和LENGTH函数,并将它们的结果作为两个列返回。在这个例子中,因为每个字符都只占用一个字节,所以两个函数返回的结果是相同的。

如果我们使用一个多字节字符,例如一个包含中文的字符串:

SELECT CHAR_LENGTH('你好,世界')AS char_length, LENGTH('你好,世界')AS length;

输出:

+-------------+--------+
| char_length | length |
+-------------+--------+
|5|15|
+-------------+--------+

在这个例子中,我们将包含中文的字符串’你好,世界’作为参数传递给CHAR_LENGTH和LENGTH函数,并将它们的结果作为两个列返回。由于中文字符需要使用多个字节来表示,所以LENGTH函数返回的结果是包含中文字符的字节数,即15。而CHAR_LENGTH函数返回的结果是中文字符个数,即5。

因此,当需要处理多字节字符时,应该使用CHAR_LENGTH函数,而不是LENGTH函数。

5、REPLACE

REPLACE函数用于将字符串中的所有匹配项替换为另一个字符串。以下是一个示例:

SELECT REPLACE('Hello World','World','ctt')AS new_string;

输出:

+-----------------+
| new_string |
+-----------------+
| Hello ctt |
+-----------------+

在这个例子中,我们用’Universe’替换了原始字符串中的’World’。

6、UPPER和LOWER

UPPER函数将给定字符串转换为大写,而LOWER函数将其转换为小写。以下是一个示例:

SELECT UPPER('hello')AS uppercase, LOWER('WORLD')AS lowercase;

输出:

+-----------+-----------+
| uppercase | lowercase |
+-----------+-----------+
| HELLO | world |
+-----------+-----------+

在这个例子中,我们将’hello’转换为大写,并将’WORLD’转换为小写。

7、TRIM

TRIM函数用于去除字符串开头和结尾的空格。以下是一个示例:

SELECT TRIM('   Hello World   ')AS trimmed_string;

输出:

+-----------------+
| trimmed_string |
+-----------------+
| Hello World |
+-----------------+

在这个例子中,我们去除了字符串开头和结尾的空格。

8、SUBSTRING

SUBSTRING函数用于提取字符串的一部分。以下是一个示例:

SELECT SUBSTRING('Hello World',7,5)AS substring;

输出:

+-----------+
| substring |
+-----------+
| World |
+-----------+

在这个例子中,我们提取了从字符串的第7个字符开始的5个字符。

9、INSTR

INSTR函数用于返回一个字符串中第一次出现指定子字符串的位置。以下是一个示例:

SELECT INSTR('Hello World','World')AS position;

输出:

+----------+
| position |
+----------+
|7|
+----------+

在这个例子中,我们返回了字符串’Hello World’中第一次出现子字符串’World’的位置,即第7个字符。

10、LOCATE

LOCATE函数用于返回一个字符串中指定子字符串第一次出现的位置。以下是一个示例:

SELECT LOCATE('World','Hello World')AS position;

输出:

+----------+
| position |
+----------+
|6|
+----------+

在这个例子中,我们返回了字符串’Hello World’中子字符串’World’第一次出现的位置,即第6个字符。

11、LEFT和RIGHT

LEFT函数和RIGHT函数用于从字符串的左侧或右侧返回指定数量的字符。以下是一个示例:

SELECT LEFT('Hello World',5)AS left_part, RIGHT('Hello World',5)AS right_part;

输出:

+-----------+------------+
| left_part | right_part |
+-----------+------------+
| Hello | World |
+-----------+------------+

在这个例子中,我们从字符串的左侧返回了前5个字符,并从字符串的右侧返回了最后5个字符。

12、LPAD和RPAD

LPAD函数和RPAD函数用于向字符串的左侧或右侧填充指定的字符,以便使其达到指定的长度。以下是一个示例:

SELECT LPAD('123',5,'0')AS lpad_string, RPAD('123',5,'0')AS rpad_string;

输出:

+-------------+-------------+
| lpad_string | rpad_string |
+-------------+-------------+
|00123|12300|
+-------------+-------------+

在这个例子中,我们将字符串’123’使用0字符向左填充,使其长度达到5个字符,并将字符串’123’使用0字符向右填充,使其长度达到5个字符。

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/304185.html<

(0)
管理的头像管理
上一篇2025-05-25 14:44
下一篇 2025-05-25 14:45

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注