mysql中的擎天柱---InnoDB引擎

我们知道mysql常用的引擎有InnoDB和MyISAM,在mysql5.5前默认引擎是MySAM在mysql5.5之后默认引擎是InnoDB

InnoDB记录存储结构

InnoDB页简介

InnoDB是一个将表中的数据存储到磁盘上的存储引擎,所以即使关机后重启我们的数据还是存在的。
InnoDB会将数据划分为若干个页,以页作为磁盘和内存之间交互的基本单位,InnoDB中页的大小一般为 16 KB。

InnoDB行格式

主要分为四种格式
分别是Compact、Redundant、Dynamic和Compressed行格式

COMPACT行格式
在这里插入图片描述
1、变长字段长度列表
用来记录用户列中长度可变的类型,比如:VARCHAR(M)、VARBINARY(M)、各种TEXT类型,他是按照列的前后***逆序***排列
比如列名和其长度如下:

列名 长度(16进制)
列1 0x04
列2 0x03
列3 0x01

那么他的变长字段列表里存放的数据为 0x01 0x03 0x04

2、NULL值列表
我们知道表中的某些列可能存储NULL值,如果把这些NULL值都放到记录的真实数据中存储会很占地方,所以Compact行格式把这些值为NULL的列统一管理起来,存储到NULL值列表中
a)首先统计表中允许存储NULL的列有哪些。
b)如果表中没有允许存储 NULL 的列,则 NULL值列表 也不存在了,否则将每个允许存储NULL的列对应一个二进制位,二进制位按照列的顺序逆序排列

二进制位的值为1时,代表该列的值为NULL。
二进制位的值为0时,代表该列的值不为NULL。

c)MySQL规定NULL值列表必须用整数个字节的位表示,如果使用的二进制位个数不是整数个字节,则在字节的高位补0。

例如:
共有四列c1、c2、c3、c4,c2是not null的其他三列可以为null
某一行中c3、c4为null,c1其中有值
则在这个列中会存储

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值