文章目录
查看存储引擎
查看mysql提供什么存储引擎:
show engines;
#或
show engines\G
设置系统默认的存储引擎
查看默认的存储引擎:
show variables like '%storage_engine%';
#或
SELECT @@default_storage_engine;
修改默认的存储引擎
SET DEFAULT_STORAGE_ENGINE=MyISAM;
#或者修改 my.cnf 文件:
default-storage-engine=MyISAM
设置表的存储引擎
创建表时指定存储引擎
CREATE TABLE 表名(
建表语句;
) ENGINE = 存储引擎名称;
修改表的存储引擎
ALTER TABLE 表名 ENGINE = 存储引擎名称;
-- 查看
SHOW CREATE TABLE engine_demo_table\G
引擎介绍
InnoDB 引擎:具备外键支持功能的事务存储引擎
- InnoDB是MySQL的 默认事务型引擎 ,它被设计用来处理大量的短期(short-lived)事务。可以确保事务的完整提交(Commit)和回滚(Rollback)。
- 对比MyISAM的存储引擎, InnoDB写的处理效率差一些 ,并且会占用更多的磁盘空间以保存数据和索引。
- 数据文件结构:(在《第02章_MySQL数据目录》章节已讲)
– 表名.frm 存储表结构(MySQL8.0时,合并在表名.ibd中)
– 表名.ibd 存储数据和索引 - 对比MyISAM的存储引擎, InnoDB写的处理效率差一些 ,并且会占用更多的磁盘空间以保存数据和索引。
- MyISAM只缓存索引,不缓存真实数据;InnoDB不仅缓存索引还要缓存真实数据, 对内存要求较高 ,而且内存大小对性能有决定性的影响。
MyISAM 引擎:主要的非事务处理存储引擎
- MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM 不支持事务、行级锁、外键 ,有一个毫无疑问的缺陷就是 崩溃后无法安全恢复 。支持表锁
- 优势是访问的 速度快 ,对事务完整性没有要求或者SELECT、INSERT为主的应用
- 针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高
- 应用场景:只读应用或者以读为主的业务
引擎对比
MySQL中同一个数据库,不同的表可以选择不同的存储引擎。如下表对常用存储引擎做出了对比。