zoukankan      html  css  js  c++  java
  • mysql 记录(record)

    以下内容来源于《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:
      1. 表示数据在堆中的序列号,记录之间通过next record关联。由此可见record之间是一个单链表结构。
      2. record之间在物理上是按照插入时间排序,并不是按照主键值连续,这样可以减少增删的耗费,但在逻辑上按主键值连续。
      3. 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
  • 相关阅读:
    大哥带的MSsql注入(SQL Server)--预习
    大哥带我们的mysql注入 基于时间的盲注
    大哥带我们的mysql注入 基于bool的盲注
    sqli-labs(22)
    sqli-labs(21)
    sqli-labs(20)
    sqli-labs(19)
    kali文件执行的权限不够解决办法
    DVWA--XSS(反射型)
    Updatexml函数再mysql中的作用
  • 原文地址:https://www.cnblogs.com/jpfss/p/11425043.html
Copyright © 2011-2022 走看看