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的缺点:

  • 会删除列末尾的空格信息

参考:
***《高性能MySQL第3版》第四章***

欢迎关注我个人公众号:java之旅

### MySQLVARCHARCHAR区别MySQL中,`VARCHAR` `CHAR` 是两种常用的字符串数据类型,它们在存储方式、性能特性以及适用场景上存在显著差异。 #### 存储方式 `CHAR` 是固定长度的字符串类型,其存储长度由定义时指定的长度决定,无论实际存储的数据长度如何,都会占用定义的全部存储空间。例如,`CHAR(10)` 类型的字段,即使存储的是一个长度为3的字符串,也会占用10个字符的存储空间[^1]。 相比之下,`VARCHAR` 是可变长度的字符串类型,它只占用实际需要的存储空间加上1或2个字节的长度信息。这意味着,如果存储的数据长度变化较大,使用 `VARCHAR` 可以有效节省存储空间。具体来说,当实际字节数不超过255个字节时,使用一个字节记录长度;超过255个字节时,则使用两个字节记录长度[^3]。 #### 性能特性 对于 `CHAR` 类型,由于其固定长度的特性,使得在进行数据检索时,数据库可以更快地定位到数据的位置,从而可能带来一定的性能优势。然而,这种优势往往伴随着较高的存储成本[^1]。 而对于 `VARCHAR` 类型,尽管其可变长度的特性可能导致数据检索时需要额外的计算来确定数据的实际位置,但随着MySQL版本的不断升级,`VARCHAR` 类型的性能也在不断改进并提高。特别是在处理那些经常需要修改而容易形成碎片的数据表时,`VARCHAR` 类型的优势更为明显[^1]。 #### 适用场景 对于 `MyISAM` 存储引擎,推荐使用 `CHAR` 类型,尤其是对于那些经常需要修改的数据表,因为 `CHAR` 类型有助于减少数据碎片[^1]。 而对于 `InnoDB` 存储引擎,由于其内部存储机制的特点,使用 `CHAR` 类型并不一定比使用 `VARCHAR` 类型更好。实际上,考虑到 `CHAR` 类型通常会占用更多的存储空间,从减少空间占用量减少磁盘 I/O 的角度来看,使用 `VARCHAR` 类型反而更有利[^2]。 综上所述,选择 `CHAR` 还是 `VARCHAR` 类型,应根据具体的使用场景需求来决定,权衡存储效率与性能之间的关系。 ```sql -- 示例:创建包含CHARVARCHAR类型的表 CREATE TABLE example_table ( id INT PRIMARY KEY, char_column CHAR(10), varchar_column VARCHAR(10) ); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值