编码是UTF-8,每个汉字占3个字节,而字母又只有1个字节。
那么用strlen取字符串的长度的话,如果是10个汉字,就是30个了,而按照30个限制的话,字母又可以输入30个了。
1.一个汉字占多少长度与编码有关:
UTF-8:一个汉字=3个字节
GBK:一个汉字=2个字节
2.varchar(n)表示n个字符,无论汉字和英文,Mysql都能存入n个字符,仅是实际字节长度有所区别
3.MySQL检查长度,可用SQL语言:
select LENGTH(fieldname) from tablename 来查看
=========华丽丽分隔线,转载如下:==========
涉及到了字符长度问题,搜索了一下,几乎千篇一律, 所以决定自己测试一下,彻底弄清楚字符长度问题.
编码一律为 UTF-8 编码 :
先来测试一下 php 把一个汉字认作几个字节:
header(‘Content-Type:text/html;charset=UTF-8′);
$str=’我’;
echo strlen($str);
?>
输出 3 , 证明在 UTF-8编码下, 一个汉字被认作3个字节长度.
而如果我们用 php 多字节扩展函数 mb_strlen($str,’utf8′); 这个时候输出 1