1. **页大小和存储结构**:
- InnoDB存储引擎以页(Page)为单位存储和管理数据,默认页大小为16KB。其中,文件头、页头、页目录等元数据占用了一部分空间,剩下的大约15KB用来存储行记录。
2. **索引页和数据页**:
- 索引页主要存储索引和指针,数据页存储完整的行数据。对于索引页,如果主键是bigint类型(8字节)加上指针(6字节),那么每条索引记录大约占用14字节。
因此,一个索引页大约可以存放 \( \frac{15 \times 1024}{14} \approx 1280 \) 条索引记录。
3. **B+树的层级和数据量**:
- B+树的叶子节点是数据页,非叶子节点是索引页。假设B+树的高度为3层,那么可以存放的数据量大约为 1280 * 1280 * 16 = 2000 万条记录。
这个估算是基于每条记录大约占用1KB的空间,实际中这个数字会根据记录的实际大小而变化。
4. **性能考虑**:
- 当B+树的高度增加时,查询数据需要更多的磁盘I/O操作,这会增加查询延迟。同时,索引的体积也会增大,维护索引结构的复杂度也会提高,这可能导致性能下降。
标签:存储,1280,记录,2000w,索引,单表,mysql,数据,字节
From: https://www.cnblogs.com/qcy-blog/p/18575748