具體還是要看版本的
4.0版本以下,varchar(100),指的是100字節,如果存放UTF8漢字時,只能存33個(每個漢字3字節)
5.0版本以上,varchar(100),指的是100字符,無論存放的是數字、字母還是UTF8漢字(每個漢字3字節),都可以存放100個。
自己在數據庫中建個表測試下可以放多少個漢字。
示例:以5.0以上版本為例。
新建表:
CREATE TABLE varchar_test ( `id` int(11) NOT NULL , `string` varchar(20) ) ENGINE=InnoDB DEFAULT CHARACTER SET=utf8COLLATE=utf8_general_ci
插入表
INSERT INTO varchar_test (id, string) VALUES (1, '一二三四五六七八九十');
INSERT INTO varchar_test (id, string) VALUES (2, '一二三四五六七八九十一二三四五六七八九十');
INSERT INTO varchar_test (id, string) VALUES (3, '12345678901234567890');
測試結果:
1:一二三四五六七八九十
2:一二三四五六七八九十一二三四五六七八九十
3:12345678901234567890
如果插入字符超過21個,則報錯
INSERT INTO varchar_test (id, string) VALUES (3, '123456789012345678901');
[Err] 1406 - Data too long
for
column
'string'
at
row 1
可見MySQL的varchar(n)可以存儲的中文字符數和英文字符數是一致的,都是n個字符
但是在公司的mysql上插入12個字符卻沒有報錯,而是自動截取了十個字符,說明對mysql做了插入截取配置