用 CHAR_LENGTH() 获取字符串的字符数,不是字节数;它在 MySQL、PostgreSQL、SQLite 中行为一致,但 SQL Server 用 LEN() 且会截断末尾空格。CHAR_LENGTH 函数怎么用?直接回答:用 CHAR_LENGTH() 获取字符串的字符数,不是字节数。它在 MySQL、PostgreSQL、SQLite 等主流数据库里都支持,行为一致;但注意 SQL Server 用的是 LEN(),且会自动截断末尾空格------这点最容易踩坑。常见错误现象是:明明字符串末尾有空格,CHAR_LENGTH() 返回值却比预期少------那基本是你误用了 LENGTH()(返回字节数)或跑在 SQL Server 上用了 LEN()。CHAR_LENGTH('abc ') → 返回 4(含末尾空格)LENGTH('abc ') 在 UTF8mb4 下也返回 4,但 '你好 ' 会返回 7(3 字符 × 3 字节 + 1 空格),不可靠MySQL 中 CHAR_LENGTH() 和 CHARACTER_LENGTH() 完全等价,后者是标准 SQL 写法,可读性略好为什么不能用 LENGTH() 替代?因为 LENGTH() 返回的是字节数,不是字符数。在多字节字符集(如 utf8mb4)下,一个汉字占 3 或 4 字节,LENGTH() 就会严重高估"长度感"。业务上判断用户名是否超 20 个字符,用 LENGTH() 可能让一个 10 字中文名就报错。场景:校验用户昵称 ≤ 12 字符,数据库字符集为 utf8mb4错误写法:WHERE LENGTH(nickname) > 12 → 实际可能只写了 4 个汉字就触发正确写法:WHERE CHAR_LENGTH(nickname) > 12兼容提示:PostgreSQL 的 LENGTH() 行为等同于 MySQL 的 CHAR_LENGTH(),属于特例,别凭经验套用在 WHERE / ORDER BY / SELECT 中怎么安全使用?CHAR_LENGTH() 是标量函数,可以放心用于过滤、排序和投影,没有隐式类型转换风险,也不影响索引使用------但注意:对字段套函数后无法走索引,比如 WHERE CHAR_LENGTH(name) = 5 无法利用 name 上的索引。 云从科技AI开放平台 云从AI开放平台
相关推荐
Cyber4K24 分钟前
【Python专项】Nginx访问日志分析时间范围处理示例PaperData31 分钟前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF周末也要写八哥37 分钟前
代码中的注释的重要性(二)愿^O^~38 分钟前
JVM GC 入门 → 进阶XingshiXu1 小时前
【NWAFU×KUL】不打扰,也能看懂一头牛:非接触式技术正在改变精准畜牧kybs19911 小时前
springboot租车系统--附源码68701星河耀银海1 小时前
C语言与数据库交互:SQLite实战与数据持久化过期动态1 小时前
MySQL中的约束wxin_VXbishe1 小时前
springboot新能源车充电站管理系统小程序-计算机毕业设计源码29213程序员陆通1 小时前
月烧 400 刀到不到 20 刀:我是怎么把 OpenClaw 的 Token 账单砍掉 95% 的