✅对线面试官-CHAR和VARCHAR了解嘛,区别是什么

面试官:我看你们项目上用的是MySQL,相关的类型了解吗?

派大星:嗯,了解一些。

面试官:嗯,那你知道char和varchar的区别是什么嘛?简单说一说。

派大星:好的。

首先,CHAR和VARCHAR均为数据库中用于存储字符串数据的数据类型。它们之间的主要区别在于存储空间的使用方式。

比如:CHAR为一种定长数据类型,其长度固定且在存储时会自动加入空格以填满指定长度,长度范围为0至255;

VARCHAR则为一种可变长度数据类型,仅存储实际的字符串内容,无需填充空格。故在存储短字符串时,VARCHAR能够节省空间,长度范围为0至65535(适用于MySQL 5.0.3及之后版本)。

采用CHAR(100) ,插入记录后即分配了100个字符,后续修改不引起页分裂问题;而VARCHAR(100)因未预分配存储空间,初始插入数据时,可变长度字段按实际长度储存,且数据在文件中紧密连续。若值变长,原位置无法扩展,无法覆盖原空间,MySQL将采用页分裂方式扩展字段的长度。

面试官:不错,既然这样,它俩在使用的时候有什么有缺点呢?

派大星:

VARCHAR的优势 :在于其可变长度的字符类型,具有更好的兼容性;然而,使用VARCHAR可能引发内存碎片问题,需要额外1到2个字节存储长度信息,并更新语句可能导致页分裂等情况。

举例来说,适合使用VARCHAR的场景包括存储产品描述(可变长度)、用户地址(可变长度)以及用户名称(可变长度)。

CHAR的长处 在于其定长字符串类型,有助于减少内存碎片,并无需额外的磁盘空间来存储长度信息;但其短板在于会消除列末尾的空格信息。

CHAR在长度不足时会补充空格,因此,当在一个长度为10的CHAR中分别存储"paidaxing "和"paidaxing"时,实际存储的均为"paidaxing ",导致原空格信息丧失。

举例来说,适合使用CHAR的情境包括存储身份证号(固定长度)、订单号(固定长度)以及国家编码(固定长度)。

面试官:挺好,看来确实掌握的不错。

派大星:嘿嘿,谢谢,就是在使用过程中有去比较了解过。毕竟如果在设计索引的时候需要考虑,具体的索引设计原则以及优化慢SQL可参考历史文章:

mp.weixin.qq.com/s/9TBW5nrGp...

mp.weixin.qq.com/s/T4kkgOdDa...

如有问题,欢迎加微信交流:w714771310,备注- 技术交流 。或微信搜索【码上遇见你】。

免费的Chat GPT可微信搜索【AI贝塔】进行体验,无限使用。

好了,本章节到此告一段落。希望对你有所帮助,祝学习顺利。

相关推荐
RickeyBoy5 小时前
SwiftUI 如何实现 Infinite Scroll?
ios·面试
KD6 小时前
阿里云服务迁移实战(二)——网关迁移与前后端分离配置
后端
小江的记录本7 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存
颜酱7 小时前
回溯算法实战练习(3)
javascript·后端·算法
前端摸鱼匠7 小时前
【AI大模型春招面试题12】Scaling Laws揭示了模型性能、数据量、计算量之间的什么关系?
人工智能·ai·语言模型·面试·大模型
zihao_tom8 小时前
Spring Boot(快速上手)
java·spring boot·后端
楼田莉子8 小时前
MySQL数据库:MySQL的数据类型
数据库·学习·mysql
Bear on Toilet8 小时前
基于Deepseek(C++)的SSE协议流式响应实现方案
chrome·后端·deepseek接入
didiplus8 小时前
Python 入门第三课:让程序"开口说话":90% 新手都忽略的输入输出技巧
后端
明月_清风8 小时前
宿命的对决:深度对比 JavaScript 与 Python 的异步进化论
后端·python