mysql中char和varchar的区别是什么?

VARCHAR和CHAR是MySQL中的两种字符型数据类型,主要区别在于VARCHAR是可变长度,CHAR是固定长度。CHAR在空间使用上可能造成浪费但查找效率高,适合MyISAM表,特别是频繁修改的列。VARCHAR节省空间,适合InnoDB表和存储长度不确定的数据。对于非常短的或固定长度的信息,如门牌号或UUID,选择CHAR更合适。

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

区别:1、char字段的最大长度为255字符,varchar字段的最大长度为65535个字节;2、char类型在空间使用上会有浪费,而varchar类型在空间使用上比较节省;3、char类型的查找效率高,varchar类型的查找效率比较低。

VARCHAR与CHAR两种字符型数据类型,最大的差异就是VARCHAR是可变长度,而CHAR则是固定长度。在存储时,VARCHAR会根据实际存储的数据来分配最终的存储空间。而CHAR则不管实际存储数据的长度,都是根据规定的长度来分配存储空间。

适用情况:

1. 对于MyISAM表,尽量使用CHAR,对于那些经常需要修改而容易形成碎片的数据表就更是如此,它的缺点就是占用磁盘空间;

2. 对于InnoDB表,因为它的数据行内部存储格式对固定长度的数据行和可变长度的数据行不加区分(所有数据行共用一个表头部分,这个标头部分存放着指向各有关数据列的指针),所以使用char类型不见得会比使用varchar类型好。事实上,因为char类型通常要比varchar类型占用更多的空间,所以从减少空间占用量和减少磁盘i/o的角度,使用varchar类型反而更有利;

3. 存储很短的信息,比如门牌号码101,201……这样很短的信息应该用char,因为varchar还要使用1个字节用于存储信息长度,本来打算节约存储的现在得不偿失

4. 固定长度的。比如使用uuid作为主键,那用char应该更合适。因为他固定长度,varchar动态根据长度的特性就消失了,而且还要占1个字节长度信息。

5. 十分频繁改变的column。因为varchar每次存储都要有额外的计算,得到长度等工作,如果一个非常频繁改变的,那就要有很多的精力用于计算,而这些对于char来说是不需要的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风雨流年666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值