首页 > 技术分享 > MySQL
收藏

MySQL中char、varchar和text小记

01/02 18:03
大潇博客 原创文章,转载请标明出处

varchar 对每个英文(ASCII)字符都占用2个字节,对一个汉字也只占用两个字节


char 对英文(ASCII)字符占用1个字节,对一个汉字占用2个字节


varchar 的类型不以空格填满,比如varchar(100),但它的值只是"n",则它的值就是"n"


而char 不一样,比如char(100),它的值是"n",而实际上它在数据库中是"n"(n后共有99个空格,就是把它填满为100个字节)。


由于 char是以固定长度的,所以它的速度会比varchar快得多!但程序处理起来要麻烦一点,要用trim之类的函数把两边的空格去掉!


注意对于使用编码之后的char(N)/varchar(N),其中N表示当前列所允许的最大字符数.而非字节数.


4.0版本以下,varchar(50),指的是50字节,如果存放UTF8汉字时,只能存16个(每个汉字3字节)


5.0版本以上,varchar(50),指的是50字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放50个


text类型从细说:可以分为tinytext(255长度),smalltext(65535),midumtext(int最大值),longtext(long最大值)。


在mysql中,对于text类型数据和varchar/char的存储有些不同,text类型的数据,将被存储在元数据表之外地方,但是varchar/char将和其他列一起存储在表数据文件中。


text数据类型实际上将会大幅度增加数据库表文件尺寸,那么在物理存储方面有些影响,同时对text数据的检索和IO输出也会增加对内存的竞争。


很多时候,我们建议将text类型特别是长度较大或者变更频繁的数据,存储在其他专有的平台中,例如NOSQL..本质上说,不是mysql不适合存储text,而是在太多的情况下我们期望mysql能够更加高效的提供小数据查询/事务处理. 


打赏

阅读排行

大家都在搜

博客维护不易,感谢你的肯定
扫码打赏,建议金额1-10元
  • 15601023311