当前位置: 首页 > news >正文

SQL:MySQL函数:字符串函数

目录

为什么需要字符串函数?

1️⃣ LENGTH(str) — 这个字符串有几个“字节”?

2️⃣ CHAR_LENGTH(str) — 这个字符串有几个“字符”?

3️⃣ TRIM(str) — 把两边的空格剪掉

4️⃣ REPLACE(str, a, b) — 把 a 替换成 b

使用这些函数时的基本思维方法 


为什么需要字符串函数?

我们用数据库存储信息,经常会处理 文字/文本(如:用户名、推文、商品名、评论内容)。但是这些文字往往:

  • 太长、太短(需要裁剪)

  • 多余空格(要去掉)

  • 出现错别字/旧字段(要替换)

  • 需要统计长度(做验证、展示控制)

👉 所以,字符串函数 = 数据库对“文本数据”的基础处理工具
就像洗衣机、剪刀、胶水,是处理文本的“工具箱”。

1️⃣ LENGTH(str) — 这个字符串有几个“字节”?

❓ 为什么需要它?

因为数据库底层不是存文字,而是存“编码”后的字节。不同字符(尤其中英文)所占空间不同!

⚙️ 它怎么做?

  • 英文字符用 UTF-8 编码是 1 字节

  • 中文字符一般是 3 字节

举例:

SELECT LENGTH('abc');     -- 输出 3
SELECT LENGTH('你好');    -- 输出 6(因为每个汉字占 3 个字节)

🧩 用途:

  • 看数据占用多大空间

  • 检查数据长度限制(如字段最大 255 字节)

2️⃣ CHAR_LENGTH(str) — 这个字符串有几个“字符”?

❓ 为什么有它?

有时候你不关心“字节数”,只关心“有几个字”!

比如用户输入姓名“你好”,你不在意占多少空间,只关心是不是 2 个字。

⚙️ 它怎么做?

直接按“字符数”来统计,不管每个字符占几个字节。

SELECT CHAR_LENGTH('abc');     -- 输出 3
SELECT CHAR_LENGTH('你好');    -- 输出 2

🧩 用途:

  • 表单验证:用户名不能超过 10 个字符

  • 用户界面:控制展示字符数

👉 通常我们说“长度”,都推荐用 CHAR_LENGTH,而不是 LENGTH

3️⃣ TRIM(str) — 把两边的空格剪掉

❓ 为什么?

用户在输入时,可能不小心在两边加了空格,比如:

 ' John ''John',你希望它们一样对待

⚙️ 它怎么做?

只删除字符串开头和结尾的空格,中间的空格不动。

SELECT TRIM('  abc  ');  -- 输出 'abc'

🧩 用途:

  • 清洗用户输入

  • 保证字符串比较不会因多余空格失败

4️⃣ REPLACE(str, a, b) — 把 a 替换成 b

❓ 为什么?

字符串中可能有老词、错词、标记符号,要换掉:

比如把 “https” 替换为 “http”,或者把“坏词”屏蔽成“**”。

⚙️ 它怎么做?

找到所有的 a,换成 b,返回一个新字符串,不改变原数据。

SELECT REPLACE('I love apple', 'apple', 'banana');
-- 输出 'I love banana'

🧩 用途:

  • 替换敏感词

  • 批量修复字符串中的错误

  • 生成格式化内容

使用这些函数时的基本思维方法 

✅ 1. 从“数据干净吗?”出发

👉 如果数据输入时可能有异常(空格、乱码、多余字符),用 TRIM, REPLACE 清洗

✅ 2. 从“你想要的是字节?还是字符?”出发

👉 对存储空间、限制字段大小 → 用 LENGTH
👉 对显示限制、统计文字长度 → 用 CHAR_LENGTH

✅ 3. 从“原数据要不要动?”出发

这些函数大多数是不修改原数据,只返回新结果。
如果你想永久修改列数据,要配合 UPDATE

 

http://www.xdnf.cn/news/333559.html

相关文章:

  • 金仓数据库征文-金仓KES数据同步优化实践:逻辑解码与增量同步
  • 深入理解负载均衡:传输层与应用层的原理与实战
  • KRaft (Kafka 4.0) 集群配置指南(超简单,脱离 ZooKeeper 集群)还包含了简化测试指令的脚本!!!
  • WSL部署CosyVoice
  • node.js 实战——express图片保存到本地或服务器(七牛云、腾讯云、阿里云)
  • 能耗优化新引擎:EIOT平台助力企业降本增效
  • 需求分析阶段测试工程师主要做哪些事情
  • 华为云Astro后端开发中对象、事件、脚本、服务编排、触发器、工作流等模块的逻辑关系如何?以iotDA数据传输过程举例演示元素工作过程
  • 精品,架构师总结,MySQL 5.7 查询入门详解
  • trae ai编程工具
  • C++ STL入门:set 集合容器
  • 从父类到子类:C++ 继承的奇妙旅程(1)
  • Windows环境下MySQL Installer安装后执行`mysql`和`mysql -v`报错的问题解决方法
  • git 多个提交记录合并为一个
  • MySQL从入门到精通(四):SQL语言—DML
  • ts-node 深入讲解
  • Open CASCADE学习|ApplicationFramework 框架使用指南
  • linux查java进程CPU高的原因
  • 人工智能数据标注服务规范
  • SQL 更新U9C的请购单终止后不能转PO的问题
  • C++实现摩斯电码
  • 基于房屋框架结构的房屋布局大模型
  • Python操作MySQL
  • 大模型工具与案例:云服务器部署dify与使用
  • 《人工智能:如何重塑教育模式与学习图景》
  • MySQL5.6-5.7-8.0在线DDL操作锁表介绍
  • # 构建机器学习模型的桌面应用程序:从训练到部署
  • 前端实现简易 计时器
  • 多层PCB SMT贴装全流程指南:从物料准备到回流焊工艺控制
  • allegro出gerber时,单击Artwork并没有弹窗的问题