mysql 的InnoDB存储引擎 一棵B+树可以存放多少行数据?
要搞清楚这个问题,首先要从InnoDB索引数据结构、数据组织方式说起。
我们都知道计算机有五大组成部分:控制器,运算器,存储器,输入设备,输出设备。
其中很重要的,也跟今天这个题目有关系的是存储器。
我们知道万事万物都有自己的单元体系,若干个小单体组成一个个大的个体。就像拼乐高一样,可以自由组合。所以说,如果能熟悉最小单元,就意味着我们抓住了事物的本事,再复杂的问题也会迎刃而解。
存储单元
存储器范围比较大,但是数据具体怎么存储,有自己的最小存储单元。
1、数据持久化存储磁盘里,磁盘的最小单元是扇区,一个扇区的大小是 512个字节
2、文件系统的最小单元是块,一个块的大小是 4K
3、InnoDB存储引擎,有自己的最小单元,称之为页,一个页的大小是16K
扇区、块、页这三者的存储关系?
InnoDB引擎
如果mysql部署在本地,通过命令行方式连接mysql,默认的端口 3306
,然后输入密码即可进入
mysql -u root -p
查看InnoDB的页大小
show variables like 'innodb_page_size';
mysql数据库中,table表中的记录都是存储在页中,那么一页可以存多少行数据?假如一行数据的大小约为1K字节,那么按 16K / 1K = 16
,可以计算出一页大约能存放16条数据。
mysql 的最小存储单元叫做“页”,这么多的页是如何构建一个庞大的数据组织,我们又如何知道数据存储在哪一个页中?