char是一种固定长度的类型,varchar则是一种可变长度的类型,它们的区别是:
char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).
在MySQL中用来判断是否需要进行对据列类型转换的规则
1、在一个 数据表里,如果每一个数据列的长度都是固定的,那么每一个数据行的长度也将是固定的.
2、只要 数据表里有一个数据列的长度的可变的,那么各数据行的长度都是可变的.
3、如果某个 数据表里的数据行的长度是可变的,那么,为了节约 存储空间,MySQL会把这个数据表里的固定长度类型的数据列转换为相应的可变长度类型.
例外:长度小于4个字符的char数据列不会被转换为varchar类型
char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).
在MySQL中用来判断是否需要进行对据列类型转换的规则
1、在一个 数据表里,如果每一个数据列的长度都是固定的,那么每一个数据行的长度也将是固定的.
2、只要 数据表里有一个数据列的长度的可变的,那么各数据行的长度都是可变的.
3、如果某个 数据表里的数据行的长度是可变的,那么,为了节约 存储空间,MySQL会把这个数据表里的固定长度类型的数据列转换为相应的可变长度类型.
例外:长度小于4个字符的char数据列不会被转换为varchar类型
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29012686/viewspace-1146241/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29012686/viewspace-1146241/
本文阐述了MySQL中char和varchar两种数据类型的差异,char为固定长度类型,varchar为可变长度类型。char(M)会用空格填充至指定长度M,而varchar(M)仅存储实际长度加一个额外字节来记录长度。此外还介绍了MySQL如何根据列长度是否固定来决定是否转换数据类型。
1139

被折叠的 条评论
为什么被折叠?



