简述MySQL InnoDB存储引擎
前言:
存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,本篇文章将主要介绍 innodb 存储引擎相关知识。
1. innodb 简介
mysql 5.5 版本以后,默认存储引擎就是 innodb 了。innodb 是一种兼顾了高可靠性和高性能的通用存储引擎。在 mysql 5.7 中,除非你配置了其他默认存储引擎,否则执行 create table 不指定 engine 的语句将创建一个 innodb 表。
# 查看mysql支持的存储引擎 mysql> show engines; +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | engine | support | comment | transactions | xa | savepoints | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | innodb | default | supports transactions, row-level locking, and foreign keys | yes | yes | yes | | mrg_myisam | yes | collection of identical myisam tables | no | no | no | | memory | yes | hash based, stored in memory, useful for temporary tables | no | no | no | | blackhole | yes | /dev/null storage engine (anything you write to it disappears) | no | no | no | | myisam | yes | myisam storage engine | no | no | no | | csv | yes | csv storage engine | no | no | no | | archive | yes | archive storage engine | no | no | no | | performance_schema | yes | performance schema | no | no | no | | federated | no | federated mysql storage engine | null | null | null | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ # 查看默认存储引擎 mysql> show variables like 'default_storage_engine'; +------------------------+--------+ | variable_name | value | +------------------------+--------+ | default_storage_engine | innodb | +------------------------+--------+
2. innodb 优势
innodb 之所以如此受宠,主要在于其功能方面的较多优势。
1)支持事务
innodb 最重要的一点就是支持事务,可以说这是 innodb 成为 mysql 中最流行的存储引擎的一个非常重要的原因。此外 innodb 还实现了 4 种隔离级别(read uncommitted,read committed,repeatable read 和 serializable),使得对事务的支持更加灵活。
2)灾难恢复性好
innodb 通过 commit、rollback、crash-recovery 来保障数据的安全。
具体来说,crash-recovery 就是指如果服务器因为硬件或软件的问题而崩溃,不管当时数据是怎样的状态,在重启 mysql 后,innodb 都会自动恢复到发生崩溃之前的状态。
3)使用行级锁
innodb 改变了 myisam 的锁机制,实现了行锁。虽然 innodb 的行锁机制是通过索引来完成的,但毕竟在数据库中大部分的 sql 语句都要使用索引来检索数据。行锁定机制也为 innodb 在承受高并发压力的环境下增强了不小的竞争力。
4)实现了缓冲处理
innodb 提供了专门的缓冲池,实现了缓冲管理,不仅能缓冲索引也能缓冲数据,常用的数据可以直接从内存中处理,比从磁盘获取数据处理速度要快。在专用数据库服务器上,通常会将最多80%的物理 memory 分配给缓冲池。
5)支持外键
innodb 支持外键约束,检查外键、插入、更新和删除,以确保数据的完整性。存储表中的数据时,每张表的存储都按主键顺序存放,如果没有显式在表定义时指定主键,innodb 会为每一行生成一个6字节的 rowid ,并以此作为主键。
总结:
本篇文章简单介绍了 innodb 存储引擎及其优势,想深入学习 mysql ,innodb 绝对是一块绕不开的重点知识。关于 innodb 的内容还有很多,后面有机会的话可以多写写。
以上就是简述mysql innodb存储引擎的详细内容,更多关于mysql innodb存储引擎的资料请关注其它相关文章!
上一篇: 解决局域网某些网页不能访问的现象
下一篇: 详解MySQL8.0 字典表增强