14.8.3 Physical Row Structure of InnoDB Tables InnoDB 表的物理行结构
14.8.3 Physical Row Structure of InnoDB Tables InnoDB 表的物理行结构 一个InnoDB 表的物理行结构取决于在创建表指定的行格式 默认, InnoDB 使用Antelope file format 和它的COMPACT 行格式。 REDUNDANT format 是可用的来保持兼容性和MySQL 老的版本。 当你启用 innodb_file_per_table setting, 你也可以使用新的Barracuda file format, 使用它的DYNAMIC and COMPRESSED row formats。 检查InnoDB表的行格式,你可以使用SHOW TABLE STATUS. For example: 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: 你也可以检查InnoDB表的行格式通过查询INFORMATION_SCHEMA.INNODB_SYS_TABLES. mysql> SELECT NAME, ROW_FORMAT FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE NAME='test1/t1';
+----------+------------+
| NAME | ROW_FORMAT |
+----------+------------+
| test1/t1 | Compact |
+----------+------------+ Redundant Row Format Characteristics 荣誉行格式特性: 在InnoDB 表使用 REDUNDANT row format 有下面的特点: 1. 每个index 记录包含一个6字节的header,header 是用于把连续的记录连接起来,也用于 row-level locking. 2.记录在 clustered index 包含字段用于所有用户定义的列,此外,有一个6个字节的 transaction ID field 和一个7个字节的指针字段 3.如果一个表没有定义主键, 每个clustered index record 也包含一个6字节的row ID字段 4.每个secondary index record 也包含所有的主键字段 定义用于clustered index key 5.一个记录包含一个支点到每个记录的字段,如果字段的总长度在一个记录是小于128字节,指针是1个字节 否则 指针是2个字节。 这些指针的数组被称为记录目录,这些指针指向区域被称为 记录的数据部分 6. 在内部, InnoDB 存储固定长度的字符串列 比如CHAR(10) 以一个固定长度格式。 InnoDB 不会截断VARCHAR列两侧的空格 7.InnoDB 编码固定长度字段大于或者等于768字节 8.一个SQL NULL 值存储一个或者2个字节在记录目录。 除此之外, 一个SQL NULL 值 存储0个字节在记录的数据部分 如果存储在可变成都列。 在一个固定长度列,他存储列的固定长度在记录的数据部分。 COMPACT Row Format Characteristics 紧凑的行格式 COMPACT row format 降低了约20%的行存储空间相比 REDUNDANT format 增加了CPU 使用对于一些操作。 如果你的负载时是典型的受限于cahce 命中率和磁盘速度, COMPACT format 是看起来更快的。 如果你的负载是受限于CPU 速度,compact format 可能会更慢 在InnoDB 表中使用COMPACT row format 有下面的特点: 1. 每个index record 包含一个5个字节的header 通过一个可变长度的header , header是用于把联系的记录连接起来,也用于row-level locking 2. 记录header 是跟在非NULL列的数据内容的后面 3.记录在 clustered index 包含字段用于所有用户定义的列,此外, 有一个6字节的事务ID 字段和一个7字节的指针字段 4. 如果表没有一个主键,每个clustered index record 也包含一个6字节的row id字段 5.每个secondary index record 也包含所有的主键字段 定义用于clustered index key 如果任何主键字段是可变长度, record header对于每个 secondary index 有一个可变部分来记录它们的长度,即使 secondary index 是定义在可变长度列 6.InnoDB 不截断去掉 VARCHAE列两侧的空格
14.8.3 Physical Row Structure of InnoDB Tables InnoDB 表的物理行结构的更多相关文章
- 14.2.5.7 Physical Row Structure 物理数据结构:
14.2.5.7 Physical Row Structure 物理数据结构: InnoDB物理记录结构依赖行格式 在表创建的时候, 默认, InnoDB 使用Antelope 文件存储格式和它的压缩 ...
- 14.6.7?Limits on InnoDB Tables InnoDB 表的限制
14.6.7?Limits on InnoDB Tables InnoDB 表的限制 警告: 不要把MySQL system tables 从MyISAM 到InnoDB 表. 这是不支持的操作,如果 ...
- 14.8.2 Role of the .frm File for InnoDB Tables InnoDB 表得到 .frm文件的作用
14.8.2 Role of the .frm File for InnoDB Tables InnoDB 表得到 .frm文件的作用 Vsftp:/data01/mysql/zjzc# ls -lt ...
- 14.2.5.1 Role of the .frm File for InnoDB Tables InnoDB .frm文件的作用
14.2.5.1 Role of the .frm File for InnoDB Tables: 14.2.5.1 Role of the .frm File for InnoDB Tables I ...
- InnoDB存储引擎表的逻辑存储结构
1.索引组织表: 在InnoDB存储引擎中,表都是依照主键顺序组织存放的.这样的存储方式的表称为索引组织表,在innodb存储引擎表中,每张表都有主键.假设创建的时候没有显式定义主键,则Inn ...
- 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. ...
- mysql的innodb 引擎 表锁与行锁
innodb 引擎 行锁与表锁 行锁与表锁是基于索引来说的(且索引要生效) 不带索引 (表锁)要全表扫描 1. 执行select @@autocommit; 查看结果 0是不自动提交事务,1是自动提交 ...
- 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 ...
- 14.8.11 Physical Structure of an InnoDB Index InnoDB Index 的物理结构
14.8.11 Physical Structure of an InnoDB Index InnoDB Index 的物理结构 所有的InnoDB indexes 是 B-trees Index r ...
随机推荐
- git的一些基础命令
Git常用命令 请确保已经安装里git客户端 一般配置 git --version //查看git的版本信息 git config --global user.name //获取当前登录的用户 git ...
- MKServerBuilder.psd1
MKServerBuilder.psd1 # # Module manifest for module 'MKServerBuilder' # # Generated by: Edward Guan ...
- MSDN Webcast 系列课程
云计算(Cloud) 云起龙骧系列课程 网络开发(Web) ASP.NET 4 风云之旅系列课程 ASP.NET 开发实践系列课程 MOSS2007 最佳实战 StepByStep 系列课程 Silv ...
- Unty3D动态加载图片
试验动态加载图片,代码如下: using UnityEngine; using System.Collections; public class DynamicLoad : MonoBehaviour ...
- css hack方法总结
IE6识别:下划线 _ 和 星号 *IE7识别:星号 *IE6-IE10识别: \9 css hack方式,条件注释法<!--[if IE]>这段文字只在IE浏览器显示<![endi ...
- [弹出消息] C#MessageBox帮助类 (转载)
点击下载 MessageBox.rar 主要功能如下所示1.显示消息提示对话框 2.控件点击 消息确认提示框 3.显示消息提示对话框,并进行页面跳转 4.输出自定义脚本信息 /// <summa ...
- C# 实现的多线程异步Socket数据包接收器框架
转载自Csdn : http://blog.csdn.net/jubao_liang/article/details/4005438 几天前在博问中看到一个C# Socket问题,就想到笔者2004年 ...
- C#调用ActiveX控件
背景:最近项目中需要用到ActiveX控件,项目是在.Net平台下开发的.因此就直接在项目中添加了对ActiveX控件的引用,添加引用成功.在代码中实例化类的实例也没有问题,但在调用其方法或属性时总是 ...
- C# 跨线程调用问题
纠结了好久,终于知道了winform和WPF的UI的跨线程调用的解决方法: winform下如果为了省事,可以直接禁用跨线程检查: Control.CheckForIllegalCrossThread ...
- Mysql DB2等数据库分页的实现
一.Mysql的分页 (一).MySQL分页的实现,使用关键字:Limit 语法:select * from tableName Limit A,B; 注释:tableName:表名 A:查询的 ...