当前位置: 首页 > news >正文

【MySQL】基础篇

1. MySQL中的NULL值是怎么存放的?

MySQL的compact行格式中会用【NULL值列表】来标记值为NULL的列,NULL值不会存储在行格式中的真实数据部分。
NULL值列表会占用1字节空间,当表中所有字段都被定义成NOT NULL,行格式中就不会有NULL值列表,可节省1字节空间
【1字节8位,每位用0或1填充,0代表不是NULL,1代表为NULL,用0补齐成8位,当列较多时,NULL值列表占用的字节空间可变。】

2.MySQL怎么知道varchar(n)实际占用数据的大小?

MySQL的Compact行格式中会用【变长字段长度列表】存储变长字段实际占用的数据大小。

3.varchar(n)中n最大取值为多少?

一行记录最大能存储65535字节的数据,但这个是包含【变长字段字节数列表所占用的字节数】和【NULL值列表所占用的字节数】。所以,在算varchar(n)中最大值时,需要减去这两个列表所占用的字节数。
如果一张表只有一个varchar(n)字段,且允许为NULL,字符集为ascii。varchar(n)中n最大取值为65536-变长字段字节数列表所占用的字节数-null值列表所占用的字节数=65535-2-1=【65532】。
如果有多个字段的话,要保证所有字段的长度+变长字段字节数列表所占用的字节数+NULL值列表所占用的字节数<=65535。

4.行溢出后,MySQL是怎么处理的?

如果一个数据页存不了一条记录,InnoDB存储引擎会自动将溢出的数据存放在【溢出页】中。
Compact行格式:当发生行溢出时,在记录的真实数据处只会保存该的一部分数据,剩余数据放在【溢出页】中,然后真实数据处用【20字节】存储指向溢出页的地址,从而找到剩余数据所在的页。
Compressed和Dynamic两种格式采用【完全的行溢出】方式,记录的真实数据处不会存储该列的一部分数据,只存储20个字节的指针来指向溢出页。实际的数据全部存储在溢出页中。

http://www.lryc.cn/news/536332.html

相关文章:

  • vscode环境搭建
  • tp whereOr用法2
  • 前端面试题目---页面抖动的原因、如何避免、如何解决
  • Spring Boot整合DeepSeek实现AI对话(API调用和本地部署)
  • DeepSeek 的 API 服务引入 WPS Office
  • 在Vue中,JavaScript数组常用方法,添加,插入,查找,删除等整理
  • 树莓派上 基于Opencv 实现人脸检测与人脸识别
  • Unity 接入Tripo 文生模型,图生模型
  • Redis常见数据结构
  • fps动作系统9:动画音频
  • 十四、GitLab 流水线自动化部署之 Windows Server
  • 数据库数据恢复—MongoDB丢失_mdb_catalog.wt文件导致报错的数据恢复案例
  • mysql8.0使用MGR实现高可用与利用MySQL Router构建读写分离MGR集群
  • 基于Ubuntu2404搭建k8s-1.31集群
  • Golang的图形编程应用案例
  • PostgreSQL 错误代码 23505 : ERROR: duplicate key value violates unique constraint
  • 基于SpringBoot和PostGIS的省域“地理难抵点(最纵深处)”检索及可视化实践
  • MySQL InnoDB引擎 MVCC
  • 服务器使用centos7.9操作系统前需要做的准备工作
  • 【Prometheus】prometheus结合cAdvisor监控docker容器运行状态,并且实现实时告警通知
  • 【Stable Diffusion模型测试】测试ControlNet,没有线稿图?
  • 算法刷题-数组系列-卡码网.区间和
  • Druid GetConnectionTimeoutException解决方案之一
  • 【JavaScript爬虫记录】记录一下使用JavaScript爬取m4s流视频过程(内含ffmpeg合并)
  • CSDN2024年度总结|乾坤未定你我皆是黑马|2025一起为了梦想奋斗加油少年!!!
  • 【前端】 react项目使用bootstrap、useRef和useState之间的区别和应用
  • 联想电脑如何进入BIOS?
  • 蓝桥杯单片机大模板(西风)
  • 20250213刷机飞凌的OK3588-C_Linux5.10.209+Qt5.15.10_用户资料_R1
  • 2.13学习记录