前言

前端截图显示接口报错为:ERROR 1406 (22001): Data too long for column 'desc' at row 1,一眼看出表字段设置的长度不够。

修复 bug 后记录

Value CHAR(4) Storage Required VARCHAR(4) Storage Required
' ' '    ' 4 bytes ' ' 1byte
'ab' 'ab' 4 bytes 'ab' 3 bytes
'abcd' 'abcd' 4 bytes 'abcd' 5 bytes
'abcdefgh' 'abcd' 4 bytes 'abcd' 5 bytes

上表来自 MySQL 文档

char (n): 固定长度字符串,n 表示要存储的最大字符数,范围( 0 ~ 255 )
varchar (n):可变长度字符串,长度可以指定为0到65535之间的值(实际上由于字符数大于255后保存字符长度需要2个字节,所以长度最大可为65533字节)。 VARCHAR的有效最大长度取决于最大行大小(65535字节,在所有列之间共享)和所使用的字符集。

MySql 5.0 以上的版本:

  1. 一个汉字占多少长度与编码有关:
    • UTF-8:一个汉字 = 3个字节,英文是一个字节
    • GBK: 一个汉字 = 2个字节,英文是一个字节
    • utf8mb4: 一个汉字 = 4个字节,英文是一个字节
  2. varchar(n) 表示n个字符,无论汉字和英文,MySql都能存入 n 个字符,仅实际字节长度有所区别。
  3. MySQL检查长度,可用 SQL 语句 SELECT LENGTH(fieldname) FROM tablename

utf-8 字符集中,最多可以存储(65535 -2) / 3 = 21844 个汉字
gbk 字符集中,最多可以存储(65535 - 2) / 2 = 32766 个汉字

但是,并不是说能够存储这么多就必须存储这么多的字符,考虑到各种原因,建议长度不要超过 255 个字符。需要存储大文本数据,可以使用 text 为字段类型。

参考: