MySQL系列之七 MySQL存储引擎
时间:2022-05-30 13:49:42|栏目:MySQL|点击: 次
一、MyISAM存储引擎
缺点:
- 不支持事务
- 最小粒度锁:表级
- 读写相互阻塞,写入不能读,读时不能写
- 不支持MVCC(支持多版本并发控制机制)
- 不支持聚簇索引
- 不支持数据缓存
- 不支持外键
- 崩溃恢复性较差
优点:
- 最大支持256TB存储空间
- 读取数据较快,占用资源较少
MyISAM引擎存储文件:
- tbl_name.frm: 表格式定义
- tbl_name.MYD: 数据文件
- tbl_name.MYI: 索引文件
适用场景:MySQL5.5.5前默认的数据库引擎,在只读(或者写较少)、表较小(可以接受长时间进行修复操作)的场景适用
二:InnoDB存储引擎
特点:
- 64TB
- 支持事务
- 行级锁
- 支持多版本并发控制机制(MVCC)
- 支持聚簇索引
- 支持数据缓存
- 支持外键
InnoDB数据库文件:
- tb_name.frm:表格式定义
- tb_name.ibd :数据文件
注意:默认所有的innodb表数据文件存储在数据库目录下的ibddata1, ibddata2, ... ,这样极其不方便管理
强烈建议:启用 innodb_file_per_table=ON,每个表单独使用一个表空间存储表的数据和索引
启用:innodb_file_per_table
编辑/etc/my.cnf在[mysqld]下添加 innodb_file_per_table 重启服务器 # service mysqld restart MariaDB [(none)]> SHOW VARIABLES LIKE 'innodb_file_per_table'; +-----------------------+-------+ | Variable_name | Value | +-----------------------+-------+ | innodb_file_per_table | ON | +-----------------------+-------+
您可能感兴趣的文章
- 05-31MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
- 05-31MySQL索引失效十种场景与优化方案
- 05-31MYSQL 高级文本查询之regexp_like和REGEXP详解
- 05-31MySQL获取binlog的开始时间和结束时间(最新方法)
- 05-31MySQL索引查询的具体使用
- 05-31基于MySQL和Redis扣减库存的实践
- 05-31关于MySQL的存储过程与存储函数
- 05-31MySQL实战文章(非常全的基础入门类教程)
- 05-31MySQL Flink Watermark实现事件时间处理的关键技术
- 05-31MySQL Flink实时流处理的核心技术之窗口机制
阅读排行
推荐教程
- 05-30Navicat for MySQL 11注册码激活码汇总
- 05-27Mysql误删数据快速恢复
- 05-31VS2022连接数据库MySQL并进行基本的表的操作指南
- 05-30解决seata不能使用mysql8版本的问题方法
- 05-30MYSQL字符集设置的方法详解(终端的字符集)
- 05-30解决MySQL启动报错:ERROR 2003 (HY000): Can't con
- 05-30关于Mysql-connector-java驱动版本问题总结
- 11-22mac下安装mysql忘记密码的修改方法
- 05-30MySQL中的隐藏列的具体查看
- 11-22mysql exists与not exists实例详解