现在的位置: 首页 > 数据库 > 正文

Mysql中varchar和text小记

2020年05月02日 数据库 ⁄ 共 694字 ⁄ 字号 评论关闭

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能够更加高效的提供小数据查询/事务处理.

抱歉!评论已关闭.