mysql varchar char 区别

本文探讨了数据库中char与varchar两种数据类型的特性与应用场景。char类型固定长度且效率高,适合存储较短且长度固定的文本;而varchar类型长度可变,更节省空间,适用于长度变化较大的文本存储。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值