mysql如何使用length计算字符串长度

来源:这里教程网 时间:2026-02-28 20:10:06 作者:

在 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
<p>SELECT 
LENGTH('中国') AS byte_len, 
CHAR_LENGTH('中国') AS char_len;    -- byte_len=6, char_len=2</p>

实际应用场景

当你需要验证字段存储大小、限制输入字节长度(如某些协议要求)或分析数据存储开销时,LENGTH() 很有用。

比如检查用户昵称是否超过 20 个字节:

SELECT nickname 
FROM users 
WHERE LENGTH(nickname) > 20;

基本上就这些。记住:LENGTH 看的是字节,不是字符个数,特别是在使用 UTF8 或 UTF8MB4 字符集时要特别注意。

相关推荐

热文推荐