mysql里的char怎么添加数据类型_MySql中varchar和char,如何选择合适的数据类型?...

背景

学过MySQL的同学都知道MySQL中varchar和char是两种最主要的字符串类型,varchar是变长的类型,而char是固定长度。那关于如何选择类型就成为令人头疼的事,很多初学者为了保证业务兼容性强,存储字符串类型一律都是varchar类型。这是不妥的,需要根据varchar和char的特性来进行选择。

varchar和char数据类型的区别

varchar类型用于存储可变长的字符串,是比较常见常用的字符串数据类型,在存储的字符串是变长时,varchar更加节约空间。由于varchar是变长的,在使用update的时候,可能使得行变得比原来更长,这就导致需要做额外的工作。如果一个行占用的空间增加,并且在页内没有多余的空间可与存储,这是innoDB的存储引擎需要分裂页来使行可以放进页内。

char类型是定长的。在存储数据时,MySQL会删除所有文末的空格,所以,即便你存储的是:'abc ',注意这个字符串末尾是有空格的,也会在存储时把这个空格删掉,这点需要注意。

适用的场景

varchar适用的场景:

字符串列的最大长度比平均长度要大很多;

字符串列的更新很少时,因为没有或很少有内存碎片问题;

使用了UTF-8这样复杂的字符集,每个字符都使用不同的字节数进行存储;

char适用的场景:

列的长度为定值时适合适用,比如:MD5密文数据

varchar和char的优缺点

varchar的优点:

变长的字符串类型,兼容性更好

varchar的缺点:

使用varchar可能会产生内存碎片

varchar会额外需要1到2个字节存储长度信息

update语句可能会导致页分裂

char的优点:

定长的字符串类型,减少内存碎片

无需额外的内存空间去存储长度信息

char的缺点:

会删除列末尾的空格信息

144455b0238cb8cd1422b315c9fe0cfb.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值