字段 | 含义 |
Table_catalog | 数据表登记目录 |
Table_schema | 数据表所属的数据库名 |
Table_name | 表名称 |
Table_type | 表类型[system view|base table] |
Engine | 使用的数据库引擎[MyISAM|CSV|InnoDB] |
Version | 版本,默认值10 |
Row_format | 行格式[Compact|Dynamic|Fixed] |
Table_rows | 表里所存多少行数据 |
Avg_row_length | 平均行长度 |
Data_length | 数据长度 |
Max_data_length | 最大数据长度 |
Index_length | 索引长度 |
Data_free | 空间碎片 |
Auto_increment | 作自增主键的自动增量当前值 |
Create_time | 表的建立时间 |
Update_time | 表的更新时间 |
Check_time | 表的检查时间 |
Table_collation | 表的字符校验编码集 |
Checksum | 校验和 |
Create_options | 建立选项 |
Table_comment | 表的注释、备注 |
详细说明:
row_format
若一张表里面不存在varchar、text以及其变形、blob以及其变形的字段的话,那么张这个表其实也叫静态表,即该表的row_format是fixed,就是说每条记录所占用的字节同样。其优势读取快,缺点浪费额外一部分空间。数据库
若一张表里面存在varchar、text以及其变形、blob以及其变形的字段的话,那么张这个表其实也叫动态表,即该表的row_format是dynamic,就是说每条记录所占用的字节是动态的。其优势节省空间,缺点增长读取的时间开销。大数据
因此,作搜索查询量大的表通常都以空间来换取时间,设计成静态表。优化
row_format
还有其余一些值:编码
DEFAULT | FIXED | DYNAMIC | COMPRESSED | REDUNDANT | COMPACTspa
修改行格式设计
ALTER TABLE table_name ROW_FORMAT = DEFAULTorm
修改过程致使:对象
fixed--->dynamic: 这会致使CHAR变成VARCHAR索引
dynamic--->fixed: 这会致使VARCHAR变成CHARci
data_free
每当MySQL从你的列表中删除了一行内容,该段空间就会被留空。而在一段时间内的大量删除操做,会使这种留空的空间变得比存储列表内容所使用的空间更大。
当MySQL对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分。若是进行新的插入操做,MySQL将尝试利用这些留空的区域,但仍然没法将其完全占用。
1.查询数据库空间碎片:
select table_name,data_free,engine from information_schema.tables where table_schema='yourdatabase';
2.对数据表优化:
optimize table `table_name`;