当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL常用的字符串函数举例说明

MySQL常用的字符串函数举例说明

来源:51cto 2023-03-07 12:33:48 0浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《MySQL常用的字符串函数举例说明》,聊聊MySQL、字符串函数,我们一起来看看吧!

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个字符。

今天带大家了解了MySQL、字符串函数的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

版本声明
本文转载于:51cto 如有侵犯,请联系study_golang@163.com删除
详解关于Redis的内存碎片清理详解关于Redis的内存碎片清理
上一篇
详解关于Redis的内存碎片清理
大厂面试:MySQL中用!=还能走索引吗?
下一篇
大厂面试:MySQL中用!=还能走索引吗?
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO  AI Mermaid 流程图:自然语言生成,文本驱动可视化创作
    AI Mermaid流程图
    SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
    659次使用
  • 搜获客笔记生成器:小红书医美爆款内容AI创作神器
    搜获客【笔记生成器】
    搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
    670次使用
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    692次使用
  • TokenPony:AI大模型API聚合平台,一站式接入,高效稳定高性价比
    TokenPony
    TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
    757次使用
  • 迅捷AIPPT:AI智能PPT生成器,高效制作专业演示文稿
    迅捷AIPPT
    迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
    647次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码