思考mysql内核之初级系列14---innodb的旧式记录结构
这篇讲的是InnoDB如何组织其最底层的行数据——旧式记录结构。作为“思考MySQL内核”系列的延伸,在讨论完簇页管理后,作者将焦点转向了页内的微观世界。 文章的核心,是剖析InnoDB在早期(兼容旧版本)使用的那套复杂而精巧的记录存储格式。这并非简单的字段拼接,而是一套涉及字段编码、NULL值处理、变长字段长度偏移,乃至溢出页指针设计的完整实现。作者通过具体的结构拆解,揭示了这套设计如何在有限的页空间内,努力兼顾存储紧凑性与读取效率,同时支持像TEXT/BLOB这样的大数据字段。 这种对“旧式”结构的深挖,其价值在于理解InnoDB演进的起点。当我们明白旧结构在面对现代复杂查询和高并发写入时,在空间管理和性能上遇到了哪些瓶颈,才能真正领会新式紧凑记录格式的改进究竟解决了哪些根本问题。对于想深入理解InnoDB存储引擎行为(比如数据页为何那样满、行锁范围如何确定)的开发者而言,这篇从最底层记录结构入手的分析,提供了一个关键视角。