首页 / MYSQL / mysql 记录(record)
mysql 记录(record)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql 记录(record),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1474字,纯文字阅读大概需要3分钟。
内容图文
![mysql 记录(record)](/upload/InfoBanner/zyjiaocheng/893/3406053119bc443ea5e1d5a5568807d5.jpg)
以下内容来源于《mysql内核:Innodb存储引擎 卷1》
简单介绍物理记录和大记录。仅为理解mysql 索引基础 存储结构这一章节而写。
mysql的默认存储引擎为Innodb。Innodb在磁盘上管理的最小单位为page(页),每个页中又以行记录方式储存。
行(row)和记录(record)是等价的,记录就是行,行就是记录。在关系型数据理论中,又把记录叫做元组(tuple)。行和元组之间也是等价的,在书中,把行作为物理记录,元组作为逻辑记录,众所周知,计算机以二进制的方式储存数据,那么行为二进制数据,而元组则为逻辑上的数据。
物理记录
物理记录共有两部分:
1. extra info:又分为col list 和 record header。
2. 实际储存行。
col list:倒叙存储列地址,是否为null,是否包含外部存储属性(extern)
record header:记录头
- n_owned:在page目录槽中采用稀疏法,不是一个记录对应一个槽,而是一个槽对应一条记录,而这个记录的n_owned属性表示该记录所拥有的记录数量。
- head no:
- 表示数据在堆中的序列号,记录之间通过next record关联。由此可见record之间是一个单链表结构。
- record之间在物理上是按照插入时间排序,并不是按照主键值连续,这样可以减少增删的耗费,但在逻辑上按主键值连续。
- head no 还有实现行锁功能。
行内容:在record header之后就是实际存储的内容了。
大数据页
一个页的大小为16K,数据行存在页上,当遇到text、blob这种大文本的时候,很有可能一个字段值就超过16k了。那Innodb又是怎么做的呢?
原来数据不仅存放在当前页上,当数据量超过范围以后就会存储在溢出页上。这种列的属性为extern。
范围
1. 总字节数大于1/2 * page_get_free_space_of_empty()(8132 bytes);
2. 列大于REC_MAX_DATA_SIZE(16k)
原文地址:https://blog.csdn.net/d57893269/article/details/53907974
内容总结
以上是互联网集市为您收集整理的mysql 记录(record)全部内容,希望文章能够帮你解决mysql 记录(record)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。