14.2.5.7 Physical Row Structure 物理数据结构:

InnoDB物理记录结构依赖行格式 在表创建的时候,  默认, InnoDB 使用Antelope 文件存储格式和它的压缩行格式。

冗余的格式是保留 和MySQL 老版本的兼容性。

当你启用 innodb_file_per_table设置,你也可以使用更新的Barracuda file format,

它的DYNAMIC 和COMPRESSED 行模式.

检查InnoDB 表的行格式,你可以使用SHOW TABLE STATUS,比如:

mysql> SHOW TABLE STATUS IN test1\G
*************************** 1. row ***************************
Name: t1
Engine: InnoDB
Version: 10
Row_format: Compact
Rows: 0
Avg_row_length: 0
Data_length: 16384
Max_data_length: 0
Index_length: 16384
Data_free: 0
Auto_increment: 1
Create_time: 2014-10-31 16:02:01
Update_time: NULL
Check_time: NULL
Collation: latin1_swedish_ci
Checksum: NULL
Create_options:
Comment: 你可以检查row format 通过查询INFORMATION_SCHEMA.INNODB_SYS_TABLES. COMPACT row 格式降低了20% 的row storage space 代价是增加CPU使用对于一些操作。 如果你的工作负载是一个典型的受限于cache命中率和disk speed. COMPACT 格式是可能更快的, 如果 负载是受限于 CPU 速度,COMPACT 格式可能会更慢。 Rows 在InnoDB 表使用冗余的行格式有下面的特点: 1.每个index 记录包含一个6位的头, header 是用于连接连续的记录,也还row-level 锁定 2. 在clustered index 中的记录包含字段用于所有用户自定义的列,此外, 有一个6字节的事务ID 字段和7字节的指针字段。 3. 如果表上没有主键,每个clustered index record包含一个8字节的row ID 子弹 4.每个secondary index record 包含所有的主键列,定义为 clustered index key 而不是secondary index 5.一个记录包含一个指针到每个记录的字段,如果字段的总长度在一个记录里是小于128字节, 指针是一个字节,否则, 是2个字节。这些指针的数组被称为记录目录, 这些指针指向的区域称为数据部分 6. 内部的,InnoDB 存储固定长度的字符列 比如CHAR(10) 在一个固定长度的格式, InnoDB 不截取VARCHAE 列两侧的空格。 7.一个SQL NULL 值保留一个或者2个字节在record directory. 除此之外, 一个SQL NULL 值储备0个字节在记录的数据部分 如果存储在一个可变的列里。 在一个固定列,它保留固定列的长度在数据部分. 在InnoDB 表的记录使用COMPACT 行格式有下面的特点: 1. 每个index 记录包含一个5字节header ,header 是用于连接连续的记录,也是在行级锁定。 2.记录header的可变长度部分包含一个位向量来表明NULL列。 如果索引中的列数可以是NULL 是N, 位向量占据上限(N/8) 字符。(举个例子,如果在任何地方从9到15列 可以是NULL, 位向量使用2个字节) 列是NULL 不会占用space 。 3. 记录header 后面跟着非空列的数据内容 4.记录在clustered index 包含字段对于所用用户定义的列,此外,有一个6字节的事务ID字段和一个7字节的指针字段 5.如果表上没有主键定义,每个clustered index记录也包含一个6字节的row ID字段 6.每个secondary index record 也包含所有的主键列定义用于 clustered index key 而 不是secondary index. 如果那些主键列字段是可变长度,record header 对于每个secondary index 会有一个可变长度部分来记录它们的长度, 即使secondary index 是定义在一个固定长度列

14.2.5.7 Physical Row Structure 物理数据结构:的更多相关文章

  1. 14.8.3 Physical Row Structure of InnoDB Tables InnoDB 表的物理行结构

    14.8.3 Physical Row Structure of InnoDB Tables InnoDB 表的物理行结构 一个InnoDB 表的物理行结构取决于在创建表指定的行格式 默认, Inno ...

  2. 14.2.5.4 Physical Structure of an InnoDB Index InnoDB Index 的物理结构

    14.2.5.4 Physical Structure of an InnoDB Index InnoDB Index 的物理结构 所有的InnoDB indexes 是B-trees ,index ...

  3. 14.9.2 Specifying the Row Format for a Table 指定 表的行格式

    14.9.2 Specifying the Row Format for a Table 指定 表的行格式 mysql> SHOW TABLE STATUS\G; *************** ...

  4. HDU 5066 Harry And Physical Teacher(物理题)

    HDU 5066 Harry And Physical Teacher 思路:利用物理里面的动量守恒公式.因为保证小车质量远大于小球.所以能够把小车质量当成无穷大带进去,得到答案为2 * v0 - v ...

  5. 专题实验 Storage structure 物理存储

    物理存储结构主要是指: extent的分配, 以及datablock 存储相关, 置于tablespace, segment 都是逻辑结构. tablespace : 逻辑结构, 没有实际物理存储. ...

  6. UVa 11995:I Can Guess the Data Structure!(数据结构练习)

    I Can Guess the Data Structure! There is a bag-like data structure, supporting two operations: 1 x T ...

  7. MySQL 5.6 Reference Manual-14.2 InnoDB Concepts and Architecture

    14.2 InnoDB Concepts and Architecture 14.2.1 MySQL and the ACID Model 14.2.2 InnoDB Multi-Versioning ...

  8. Limits on Table Column Count and Row Size Databases and Tables Table Size 最大行数

    MySQL :: MySQL 8.0 Reference Manual :: C.10.4 Limits on Table Column Count and Row Size https://dev. ...

  9. The BLOB and TEXT Types

    官网参考:https://dev.mysql.com/doc/refman/5.7/en/blob.html 字符串类型对应的存储需求 Data Type Storage Required CHAR( ...

随机推荐

  1. 建立Go工作环境

    最近在折腾Go语言,找了个开源项目nsq研究源代码.不过前两天不小心把系统搞挂了,这次又要重做一遍,记录一下,备忘. 准备: 1. vim+golang插件+ctags(新版本支持Go) 2. Go1 ...

  2. Nagiosserver端安装部署具体解释(1)

    下载地址例如以下: http://sourceforge.net/projects/nagios/files/ 具体具体下载地址:http://prdownloads.sourceforge.net/ ...

  3. MSSQL奇技淫巧

    MSSQL:获得库每个表的记录数和容量 sp_msforeachtable是MS未公开的存储过程: exec sp_msforeachtable @command1="print '?'&q ...

  4. 【译】在Asp.Net中操作PDF - iTextSharp - 利用列进行排版

    原文 [译]在Asp.Net中操作PDF - iTextSharp - 利用列进行排版 在使用iTextSharp通过ASP.Net生成PDF的系列文章中,前面的文章已经讲述了iTextSharp所涵 ...

  5. Jquery学习笔记: attr和 prop的区别,以及为html标签自定义属性

    一.自定义html标签属性 对于html文件中的html标签,可以自定义属性,如: <a href="#" id="link1" action=" ...

  6. 浅尝key-value数据库(一)——一览NoSQL

    浅尝key-value数据库(一)——一览NoSQL 最近由于一个项目的关系,研究了一下key-value数据库这个最近很火的概念.本系列从项目需求的角度分析并测试了几个key-value数据库的性能 ...

  7. 基于visual Studio2013解决C语言竞赛题之0809链表排序

     题目

  8. EFM32在使用IAR开发环境配置ICf文件以及指定程序存储地址空间

    EFM32在IAR开发环境下指定代码,数据的存储空间 为了便于后续的项目升级,管理,需要对代码,数据的存储空间加以设定,也在网上找下相关的资料,笔者水平有限, 如下内容不一定完全正确,如有错误之后,还 ...

  9. 反应堆Reactor

    mvn -h 可以看到很多命令及其用途:-am --also-make 同时构建所列模块的依赖模块:-amd -also-make-dependents 同时构建依赖于所列模块的模块:-pl --pr ...

  10. Oracle的序列

    Oracle的序列 序列介绍 序列是Oracle提供的用于产生一系列唯一数字的数据库对象. 使用序列能够实现自己主动产生主键值.序列也能够在很多用户并发环境中使用.为所实用户生成不反复的顺序数字,并且 ...