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

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 字符集时要特别注意。