Mysql的varchar(20)到底可以儲存多少箇中文字元
背景:
今天群裡問說“Mysql的varchar(20)到底可以儲存多少箇中文字元”,很多直觀回答是10個字元。這個問題其實很容易得到結果。博主就動手測試了一下。
動手測試之:
新建表:
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個,則報錯
[SQL]
INSERT INTO varchar_test (id, string)
VALUES (3, '123456789012345678901');
[Err] 1406 - Data too long for column'string' at row 1
小結:
可見MySQL的varchar(n)可以儲存的中文字元數和英文字元數是一致的,都是n個字元。
聽之不如見之,見之不如行之。
--------------------- 作者:WaveVector 來源:CSDN 原文:https://blog.csdn.net/wendingzhulu/article/details/38048657?utm_source=copy 版權宣告:本文為博主原創文章,轉載請附上博文連結!