LENGTH()返回字节长度,CHAR_LENGTH()返回字符个数;如'你好'在UTF8下LENGTH为6,CHAR_LENGTH为2;常用于验证存储大小或限制字节长度。

在 MySQL 中,LENGTH() 函数用于计算字符串的字节长度,而不是字符个数。这个区别在处理多字节字符(如中文、emoji)时尤为重要。
LENGTH() 的基本用法
使用 LENGTH(str) 可以返回字符串 str 所占用的字节数。例如:
SELECT LENGTH('hello'); -- 返回 5
SELECT LENGTH('你好'); -- 返回 6(UTF8 编码中每个中文字符占 3 字节)
SELECT LENGTH(''); -- 返回 0(空字符串)
与 CHAR_LENGTH() 的区别
很多人容易混淆 LENGTH() 和 CHAR_LENGTH():
- LENGTH():返回字节长度
- CHAR_LENGTH():返回字符个数
举例说明:
SELECT
LENGTH('MySQL') AS byte_len,
CHAR_LENGTH('MySQL') AS char_len; -- 都是 5
SELECT
LENGTH('中国') AS byte_len,
CHAR_LENGTH('中国') AS char_len; -- byte_len=6, char_len=2
实际应用场景
当你需要验证字段存储大小、限制输入字节长度(如某些协议要求)或分析数据存储开销时,LENGTH() 很有用。
比如检查用户昵称是否超过 20 个字节:
SELECT nickname FROM users WHERE LENGTH(nickname) > 20;
基本上就这些。记住:LENGTH 看的是字节,不是字符个数,特别是在使用 UTF8 或 UTF8MB4 字符集时要特别注意。










