常见的mysql存储引擎有MyISAM,InnoDB

1.存储引擎MyISAM

  (1)它不支持事务,也不支持外键,尤其是访问速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用基本都可以使用这个引擎来创建表

  (2)每个MyISAM在磁盘上存储成3个文件,其中文件名和表名都相同,但是扩展名分别为:

    .frm(表结构信息)

    MYD(MYData,数据信息)

    MYI(MYIndex,索引信息)

  特性:

    并发性与锁级别:表级锁(并发性差,对只读还可以)

               表损坏修复:check table tableName; repair table tableName

  支持的索引类型

  支持数据压缩:myisampack –b –f myIsam.MYI命令(对已经压缩的表不能进行写操作)

  限制:

  使用场景:非事务型应用(非财务应用);只读类应用(报表应用);空间类应用(空间函数jps等)

2.存储引擎InnoDB

  (1)Innodb使用表空间进行数据存储

    使用表空间配置参数:innodb_file_per_table

    ON:每一个独立表空间:tablename.ibd;

    OFF:系统表空间:ibdataX

    系统表空间和独立表空间如何选择:

    比较:

    1.系统表空间无法简单的收缩文件大小;独立表空间可以通过optimize table命令收缩文件。

    2.系统表空间会产生IO瓶颈;独立表空间可以同事向多个文件刷新数据。

    3.建议使用独立表空间(6以后为默认配置)

    把原来在系统表空间的表转移到独立表空间中的方法,步骤:

    1.使用mysqldump导出所有数据表数据;

    2.停止Mysql服务,修改参数,并删除Innoda相关文件;

    3.重启mysql服务,重建Innodb系统表空间;

    4.重新导入数据。

  (2)存储引擎Innodb特性

    Innodb数据字典信息,frm是mysql系统产生的,Undo回滚段,支持外键,AUTO_INCREMENT自动增加列属性

    Innodb是一种事务性存储引擎,完全支持事务的ACID特性(atomicity,consistency,isolation,durability),Redo Log(持久性)和Undo Log(未提交事务的回滚)

  (3)支持行级锁,可以最大程度支持并发,行级锁是由存储引擎层实现的;

    锁对主要作用是管理共享资源的并发访问,锁用于实现事务的隔离性;

    锁的类型:1.共享锁(也称读锁)2.独占锁(也称写锁)

    锁的粒度:粒度越小并发性越高1.表级锁,在mysql服务层实现2.行级锁,在存储引擎中实现

    阻塞和死锁:

      阻塞:一个事务等在另一个是事务的锁释放,称为阻塞

      死锁:两个或两个以上的事务,在执行过程中,相互占用对方的等待的资源出现的异常。系统会对其自动处理。选取对其占用资源最少的进行回滚。

    Inoodb状态检查:show engine inoodb status

     (4)适用场景:适用大多数OLTP应用

     数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing)、联机分析处理OLAP(On-Line Analytical Processing)。OLTP是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,例如银行交易。OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。 

    OLTP :系统强调数据库内存效率,强调内存各种指标的命令率,强调绑定变量,强调并发操作;
    OLAP :系统则强调数据分析,强调SQL执行市场,强调磁盘I/O,强调分区等。