1.定长和不定长
①char(M) 类型,每个值都占用 M 个字符,如果某个值小于M,mysql就会在它的右边用空格补足,在检索操作中,那些补足的空格将被去掉;
②varchar(M) 类型,每个值刚好占用够用的字节,再加上一个用来记录其长度的字节(即总长度为L+1字节)
2.存储效率比较
对计算机来说,char是定长的,处理的时候,只需要将右边的空格去掉即可,
而 varchar ,最后一个字符还是记录的字符长度,计算机处理的时候,还要计算最后这个字符,所以有额外的计算
相比较之下,char的存储效率比varchar要高;
我们可以看到char类型在存放数据的时候,中间是没有间隔的,数据本身是有空格的,但是数据段之间没有间隔,因为我们在创建列的时候已经告诉MySQL列的长度了&#