区别:1、char字段的最大长度为255字符,varchar字段的最大长度为65535个字节;2、char类型在空间使用上会有浪费,而varchar类型在空间使用上比较节省;3、char类型的查找效率高,varchar类型的查找效率比较低。
VARCHAR与CHAR两种字符型数据类型,最大的差异就是VARCHAR是可变长度,而CHAR则是固定长度。在存储时,VARCHAR会根据实际存储的数据来分配最终的存储空间。而CHAR则不管实际存储数据的长度,都是根据规定的长度来分配存储空间。
适用情况:
1. 对于MyISAM表,尽量使用CHAR,对于那些经常需要修改而容易形成碎片的数据表就更是如此,它的缺点就是占用磁盘空间;
2. 对于InnoDB表,因为它的数据行内部存储格式对固定长度的数据行和可变长度的数据行不加区分(所有数据行共用一个表头部分,这个标头部分存放着指向各有关数据列的指针),所以使用char类型不见得会比使用varchar类型好。事实上,因为char类型通常要比varchar类型占用更多的空间,所以从减少空间占用量和减少磁盘i/o的角度,使用varchar类型反而更有利;
3. 存储很短的信息,比如门牌号码101,201……这样很短的信息应该用char,因为varchar还要使用1个字节用于存储信息长度,本来打算节约存储的现在得不偿失
4. 固定长度的。比如使用uuid作为主键,那用char应该更合适。因为他固定长度,varchar动态根据长度的特性就消失了,而且还要占1个字节长度信息。
5. 十分频繁改变的column。因为varchar每次存储都要有额外的计算,得到长度等工作,如果一个非常频繁改变的,那就要有很多的精力用于计算,而这些对于char来说是不需要的