mysql 存储引擎:存储引擎也通常被称作“表类型”


查看所有支持的存储引擎

SHOW ENGINES;


查看指定表的存储引擎

SHOW TABLE STATUS [{FROM | IN} db_name] [LIKE 'pattern' | WHERE expr]

SHOW TABLE STATUS IN mydb\G;

SHOW TABLE STATUS IN mydb LIKE 't1'\G;


SHOW TABLE STATUS IN mydb WHERE Name='t1'\G;    

Name 表名

Engine 存储引擎

Version 版本

Row_format 行格式

Rows 表中的行数

Avg_row_length 平均每行包含的字节数

Data_length 表中数据总体大小,单位为字节

Max_data_length 表能够占用的最大空间,单位为字节,0表示没有上限

Index_length 索引的大小,单位为字节

Data_free 对于MyISAM表,表示已经分配但尚未使用的空间,其中包含此前删除行之后腾出来的空间

Auto_increment 下一个AUTO_INCREMENT的值

Create_time 表的创建时间

Update_time 表数据的最后一次修改时间

Check_time 使用CHECK TABLE或myisamchk最近一次检查表的时间

Collation 排序规则

Checksum 如果启动,则为表的checksum

Create_options 创建表时指定使用的其他选项

Comment 表的注释信息


InnoDB

    两种格式:

      1.innodb_file_per_table=OFF,即是用共享表空间

         每个表一个独有的格式定义文件:tb_name.frm

         还有一个默认位于数据目录下的共享的表空间文件:ibdata#

      2.innodb_file_per_table=ON,即是用独立表空间

        每个表在数据库目录下存储两个文件

          tb_name.frm

          tb_name.ibd

MyISAM:

   每个表都在数据库目录下存储三个文件

   tb_name.frm

   tb_name.MYD

   tb_name.MYI


表空间: table space ,由InnoDB管理的特有格式数据文件,内部可同时存储数据和索引

SHOW VARIABLES LIKE '%engine%';

如何修改默认存储引擎:通过default_storage_engine服务变量实现


各存储引擎的特性:

   InnoDB:

      支持事务,有事务日志

      ib_logfile0

      ib_logfile1

      支持外键约束(MyISAM不支持外键)

      支持MVCC(多版本并发控制)

      支持聚簇索引(数据和索引存放在一起)

           聚簇索引之外的其他索引,通常称之为辅助索引

       行级锁:间隙锁

       支持使用辅助索引

       支持自使用hash索引

       支持热备份(依赖此特性innodb_file_per_table=ON)


    MyISAM:

      全文索引

      支持表压缩存放:做数据仓库,能节约存储空间并提升性能

      支持空间索引

      表级锁

      延迟更新索引


      不支持事务、外键和行级锁

      崩溃后无法安全恢复数据


      使用场景:只读数据,表较小,能够忍受崩溃后的修复操作和数据丢失


    ARCHIVE

        仅支持INSERT和SELECT,支持很好压缩功能

        应用于存储日志信息,或其他按照时间序列实现的数据采集类的应用

    CSV:

        将数据存储为CSV格式,不支持索引,仅使用与数据交换场景

    BLACKHOLE:

        没有存储机制,任何发往次引擎的数据都会丢弃,其会记录二进制日志,因此,常用于多级复制架构中作中转服务器

    MEMORY:

        保存数据在内存中,内存表;常用于保存中间数据,如周期性的聚合数据等,也用于实现临时表

        支持hash索引,使用表级锁,不支持BLOB和TEXT数据类型

    MRG_MYISAM:

       是MYISAM的一个变种,能够将多个MyISAM表合并成一个虚表

    NDB: 

       是MySQL CLUSTER中专用的存储引擎、


第三方的存储引擎

  OLPT

    XtraDB:增强的InnoDB,有Percona提供

       编译安装时,下载XtraDB的源码替代MySQL存储引擎中的InnoDB的源码

    PBXT:MariaDB自带此存储引擎

       支持引擎级别的复制、外键约束,对SSD磁盘提供适当支持

       支持事务、MVCC

    TokuDB:使用 Fractal Trees索引,适用存储大数据,拥有很好的压缩比,已经被引入MariaDB


  列式数据存储引擎:

     Infobright:目前较有名的列式引擎,适用于海量数据存储场景,如PB级别,专为数据分析和数据仓库设计

     InfiniDB

     MonetDB

     LucidDB


  开源社区存储引擎:

     Aria:前身为Maria,是增强版的MyISAM(支持崩溃后安全恢复,支持数据缓存)

     Groona:全文索引引擎

     Mroonga:是基于Groona的二次开发版

     OQGraph:由open query研发,支持图(网状 )结构的存储引擎

     SphinxSE:为Sphinx全文搜索服务器提供了SQL接口

     Spider:能将数据切分成不同的分片,比较高效透明的实现了分片(shared),并支持在分片上支持并行查询


   如何选择??

      是否需要事务

      备份的类型的支持

      崩溃后的恢复

      特有的特性