mysql varchar char 区别

来源:互联网 发布:sql语言where 编辑:程序博客网 时间:2024/05/20 07:59

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是一个空间优先的定义。


0 0