存储引擎InnoDB与MyISAM

操作引擎

查看存储引擎

show engines;

image.png

设置系统默认的存储引擎

  1. 查看默认的存储引擎
show variables like '%storage_engine%';

image.png

  1. 修改默认的存储引擎
set default_storage_engine=MyISAM;

或者修改my.cnf文件:
:::tips
default-storage-engine=MyISAM

#重启服务
systemctl restart mysqld.service
:::
image.png

设置表的存储引擎

我们可以为不同的表设置不同的存储引擎,也就是说不同的表可以有不同的物理存储结构,不同的提取和写入方式。

创建表时指定存储引擎
create table 表名(
	建表语句;	
)engine=存储引擎名

image.png

修改表的存储引擎
alter table 表名 engine = 存储引擎名

image.png

InnoDB引擎与MyISAM引擎

InnoDB引擎:具备外键支持功能的事务存储引擎

  1. InnoDB是mysql的默认事务型引擎,可以确保事务的完整提交(commit)和回滚(rollback)
  2. 支持外键
  3. 对于频繁更新,删除操作可以使用事务回滚,优先使用innodb
  4. innodb是处理巨大数据量的最好的性能设计,得益于行级锁,提高了并发量
  5. 对比myisam,innodb写的处理效率差一些,并且会占用更多的磁盘空间以保存数据和索引(.ibd文件存储数据和索引)
  6. myisam只缓存索引,不缓存真实数据;innodb不仅缓存索引还要缓存真实数据,对内存要求较高,而内存大小对性能起决定性作用。

MyISAM引擎:主要的非事务处理存储引擎

  1. myisam提供了大量特性,例如全文索引,压缩,空间函数等;当myisam不支持事务,行级锁,外键。特别是崩溃后无法回滚恢复。
  2. 优势是访问速度快,对于事务完整性没有要求,或者以select,insert为主的应用。
  3. count(*)时间复杂度O(1)
  4. 数据和索引是分开存储的(.myd文件存储数据,.myi文件存储索引)
  5. 应用场景:以读为住的业务

对比

image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

指挥部在下面

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值