• MySQL表介绍


    MySQL InnoDB表介绍

    一、索引组织表

    在InnoDB引擎中,表都是根据主键顺序存放的。这种存储方式称为索引组织表,在InnoDB引擎中,每张表都有逐渐。如果没有显示定义主键,则引擎会按照以下方式选择或创建主键。

    (1)、判断表是否有非空唯一索引,如果有,则该字段为主键。如果有多个非空唯一索引,则选择第一个定义的非空索引字段作为主键(定义索引的顺序,不是定义字段的顺序)

    (2)、如果不符合上述条件,InnoDB自动创建一个6字节大小的指针。

    二、InnoDB逻辑存储结构

     从InnoDB得逻辑存储结构看,索引数据放在一个空间中,称作表空间。表空间又由段(segment),区(extend),页(page)组成。InooDB的逻辑存储结构大致如下图所示:

    1、表空间

    表空间可以看作InnoDB存储引擎逻辑存储结构的最高层,所有数据都放在表空间中。5.7默认启用参数innodb_file_per_table。每张表数据放在一个单独的表空间里边,如果关闭该参数,所有数据放在一个表空间ibdata1内。

    如果启用innodb_file_per_table该参数,每张表的表空间存放的是数据,索引,插入缓冲Bitmap页。其他类的数据,如回滚(undo)信息,插入缓冲索引页,系统事务信息,二次写缓冲等还是放在原来的共享表空间内。

    2、段

    表空间是由各个段组成的,常见有数据段、索引段、回滚段等。因为InnoDB引擎表是索引组织的,因此数据即索引,索引即数据。那么数据段即为B+树的叶子节点(图中的Leaf node segment),索引段为B+树的非索引节点(图中的Non-leaf node segment).回滚段比较特殊。

    3、区

    区是由连续页组成的空间,在任何区的情况下每个区大小为1M。为了保证区中页的连续性,InnoDB一次从磁盘申请4~5个区,默认情况下,InnoDB引擎页的大小为16KB,即一个区一共有64个连续页。

    4、页

    页是InnoDB磁盘管理的最小单位,默认每个也大小是16k。可以通过innodb_page_size修改页大小。设置完成,则表中所有页都为innodb_page_size,不可修改。除非通过mysqldump导出导入重建库。

    常见的页类型有:

    (1)、数据页(B-tree Node)

    (2)、undo页(undo Log Page)

    (3)、系统页(System Page)

    (4)、事务数据页(Transaction System Page)

    (5)、插入缓冲位图页(Insert Buffer Bitmap)

    (6)、插入缓冲空闲列表页(Insert Buffer Free List)

    (7)、未压缩的二进制大对象页(Uncompressed BLOB Page)

    (8)、压缩的二进制大对象页(compressed BLOB Page)

    5、行

    InnoDB引擎数据是按行进行存放的。每个页存放的行记录也是有定义的。最多允许存放16KB/2 -200,即最多7992行记录

  • 相关阅读:
    腾讯云分配子域名
    回调函数
    caution
    科普知识图谱
    SQLServer 日期函数大全
    如何进行库存管理?
    SSIS高级转换任务—执行SQL语句
    运行SSIS包的几种方式
    SSIS+CDC 增量抽取数据
    Notepad++中没有Plugin Manager怎么办
  • 原文地址:https://www.cnblogs.com/jkin/p/10287686.html
Copyright © 2020-2023  润新知