1. 程式人生 > >Mysql的varchar(20)到底可以儲存多少箇中文字元

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 版權宣告:本文為博主原創文章,轉載請附上博文連結!