操作引擎
查看存储引擎
show engines;
设置系统默认的存储引擎
- 查看默认的存储引擎
show variables like '%storage_engine%';
- 修改默认的存储引擎
set default_storage_engine=MyISAM;
或者修改my.cnf文件:
:::tips
default-storage-engine=MyISAM
#重启服务
systemctl restart mysqld.service
:::
设置表的存储引擎
我们可以为不同的表设置不同的存储引擎,也就是说不同的表可以有不同的物理存储结构,不同的提取和写入方式。
创建表时指定存储引擎
create table 表名(
建表语句;
)engine=存储引擎名
修改表的存储引擎
alter table 表名 engine = 存储引擎名
InnoDB引擎与MyISAM引擎
InnoDB引擎:具备外键支持功能的事务存储引擎
- InnoDB是mysql的默认事务型引擎,可以确保事务的完整提交(commit)和回滚(rollback)
- 支持外键
- 对于频繁更新,删除操作可以使用事务回滚,优先使用innodb
- innodb是处理巨大数据量的最好的性能设计,得益于行级锁,提高了并发量
- 对比myisam,innodb写的处理效率差一些,并且会占用更多的磁盘空间以保存数据和索引(
.ibd
文件存储数据和索引) - myisam只缓存索引,不缓存真实数据;innodb不仅缓存索引还要缓存真实数据,对内存要求较高,而内存大小对性能起决定性作用。
MyISAM引擎:主要的非事务处理存储引擎
- myisam提供了大量特性,例如全文索引,压缩,空间函数等;当myisam不支持事务,行级锁,外键。特别是崩溃后无法回滚恢复。
- 优势是访问速度快,对于事务完整性没有要求,或者以select,insert为主的应用。
- count(*)时间复杂度O(1)
- 数据和索引是分开存储的(
.myd
文件存储数据,.myi
文件存储索引) - 应用场景:以读为住的业务