当前位置: 首页 > 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.dtcms.com/a/178288.html

相关文章:

  • 深入解析:如何正确处理业务空值与技术异常?从避免滥用`None`和`WebDriverException`谈起
  • ERC-20与ERC-721:区块链代币标准的双星解析
  • 【知识点】三维项目中关于各种坐标系的初步认识
  • 2.3 点云数据存储格式——LiDAR专用型点云存储格式
  • 【Linux网络】Socket 编程预备
  • 极简远程革命:节点小宝 — 无公网IP的极速内网穿透远程解决方案
  • 用NVivo革新企业创新:洞悉市场情绪,引领金融未来
  • 科学发现 | 源于生活的启示与突破计划的创新
  • Python中,正则表达式,
  • Excel学习笔记
  • 【数据结构】——链表OJ(下)
  • K8s网络从0到1
  • 什么是变量提升?(形象的比喻)
  • 代码随想录算法训练营第三十七天-2|动态规划part2
  • CSS:字体和文本样式
  • Docker 常用命令
  • Google AI版图:解析AI Studio, Gemini, NotebookLM与GCP
  • 【Rust错误处理】Rust错误处理机制详解与应用实战
  • Yolo迁移训练-带训练源码
  • pip下载tmp不够
  • Git 基础操作系列2: 本地项目上传至git仓库(gitee / gitlab / github)
  • ITTIA DB Lite 9.x——一款高性能嵌入式事务型、时间序列嵌入式数据库
  • threejs 添加css3d标签 vue3
  • 自然语言到 SQL 转换:开启智能数据库交互新时代
  • cursor平替,试试 vscode+cline+openrouter 的方案,还能自定义 mcp-server 教程大纲
  • 【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.2 流量转化漏斗分析
  • 企业微信自建消息推送应用
  • 技术视界 | 青龙机器人训练地形详解(三):复杂地形精讲之台阶
  • 二本计算机,毕业=失业?
  • 初识Linux · TCP基本使用 · 回显服务器