1:varchar() 是变长存储,括号内为最大存储字节数,当低于255的时候,vachar需要用一个字节来存储长度,如果大于255,则需要两个字节来存储。char则是定义多少就用多少字节。当存入的数据不足时,会用空格来补齐。
2:varchar对空间是节省的,但char的效率更高一些。
3:现有磁盘如此廉价情况下,存储一些较少字节的数据时用char更合适一些,如下图,当存储四个字节的时候不同的情况不见的varchar就比char用的少。
值 |
CHAR(4) |
存储需求 |
VARCHAR(4) |
存储需求 |
'' |
<span ' ' |
4个字节 |
'' |
1个字节 |
'ab' |
<span 'ab ' |
4个字节 |
'ab ' |
3个字节 |
'abcd' |
'abcd' |
4个字节 |
'abcd' |
5个字节 |
'abcdefgh' |
'abcd' |
4个字节 |
'abcd' |
5个字节 |
4:当末尾有空格的时候,char会把数据右边所有的空格删除,因此如果数据右边有空格是看不到的。
总的来说,char是一个效率优先的定义,varchar是一个空间优先的定义。