欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

Mysql中varchar和text小记

程序员文章站 2022-06-02 08:08:06
...

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 Varchar 对每个英文(ASCII)字符都占用2个字节,对一个汉字也只占用两个字节 char 对英文(ASCII)字符占用1个字节,对一个汉字占用2个字节 Varchar 的类型不以空格填满,比如varchar(100),但它的值只

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入

  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表示当前列所允许的最大字符数.而非字节数.

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

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

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

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

Mysql中varchar和text小记