学习笔记-MySQL的存储引擎

        存储引擎就是存储数据、建立索引、更新,查询数据等技术的实现方式。存储引擎是基于表的,而不是基于库的,所以存储引擎也可被称为表类型。

        1.我们可以查看当前数据库支持的存储引擎,

show engines;

        2.我们也可以在创建表时,指定存储引擎 

CREATE TABLE 表名(
......

) ENGINE=InnoDB;

        创建表的默认存储引擎也为InnoDB,我们手动指定该表的存储引擎类型为InnoDB。

        常见存储引擎特点:

        1. InnoDB 

        介绍:InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,在MySQL5.5之后,InnoDB是默认的的MySQL存储引擎。

        特点:

  1. DML操作遵循ACID模型,支持事务
  2. 行级锁,提高并发访问性能
  3. 支持外键FOREIGIN KEY约束,保证数据的完整性和正确性

        文件:

        xxx.idb  : xxx代表的是表名,InnoDB引擎的每张表都会对应这样一个表空间文件,存储该表的结构(frm,sdi)、数据和索引。

        参数 : innodb_file_per_table

        2.MyISAM

        介绍: MyISAM是MySQL早期的默认存储引擎

        特点: 

  1. 不支持事务,不支持外键
  2. 支持表锁,不支持行锁
  3. 访问速度快

        文件:

        对于MySIAM存储引擎的表在磁盘中对应的文件有三个

        xxx.sdi :存储表结构信息

        xxx.MYD :存储数据

        xxx.MYI :存储索引

        3.Memory

        介绍:Memory引擎的表数据是存储在内存中的,由于受到硬件问题,或断电问题的影响,只能将这些表作为临时表或缓存使用。

        特点:

  1. 内存存放,访问速度快
  2. hash索引(默认)

        文件:

        xxx.sdi :存储表结构信息

        存储引擎的选择:

        在选择存储引擎时,要根据应用系统的特点去选择合适的存储引擎,InnoDB支持事务,外键。如果应用对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作包含很多更新、删除操作,则InnoDB存储引擎是非常合适的选择。如果应用对事务的完整性,并发性要求不是很高,且以读操作和插入操作为主,则选择MyISAM存储引擎很合适。作为临时诗句存储可选择MEMORY存储引擎,但是MEMORY对表的大小有限制,且无法保证数据的安全性。实际使用,后两种存储引擎使用较少,因为出现了更好的替代品。

        以上内容均学自黑马MySQl课程。

你可能感兴趣的:(mysql)