mysql 數據庫varchar存儲漢字


具體還是要看版本的

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做了插入截取配置

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM