当前位置: 移动技术网 > IT编程>数据库>Mysql > 简述MySQL InnoDB存储引擎

简述MySQL InnoDB存储引擎

2020年08月19日  | 移动技术网IT编程  | 我要评论
前言:存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,本篇文章将主要介绍 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存储引擎的资料请关注移动技术网其它相关文章!

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

  • Ubuntu上Vim安装NERDTree插件的详细操作步骤

    Ubuntu上Vim安装NERDTree插件的详细操作步骤

    nerdtree是vim的文件系统浏览器,使用此插件,用户可以直观地浏览复杂的目录层次结构,快速打开文件以进行读取或编辑,以及执行基本的文件系统操作。nerdt... [阅读全文]
  • MySQL 4种常用的主从复制架构

    MySQL 4种常用的主从复制架构

    一主多从复制架构在主库读取请求压力非常大的场景下,可以通过配置一主多从复制架构实现读写分离,把大量的对实时性要求不是特别高的读请求通过负载均衡分部到多个从库上(... [阅读全文]
  • 浅析MySQL 备份与恢复

    1、简介数据无价,mysql作为一个数据库系统,其备份自然也是非常重要且有必要去做。备份的理由千千万,预防故障,安全需求,回滚,审计,删了又改的需求等等,备份的... [阅读全文]
  • 保障MySQL数据安全的一些建议

    数据是企业核心资产,数据对企业而言是最重要的工作之一。稍有不慎,极有可能发生数据无意泄露,甚至被黑客恶意窃取的风险。每年业界都会传出几起大事件,某知名或不知名的... [阅读全文]
  • MySQL如何快速修改表的表结构

    快速修改mysql某张表的表结构--摘录自《mysql管理之道》alter table 表名 modify 列名 数据类型; 这个命令可以修改表结构此外,也可以... [阅读全文]
  • MySQL 行锁和表锁的含义及区别详解

    一、前言对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对mysql中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答。mys... [阅读全文]
  • MySQL 如何查询当前最新事务ID

    写在前面:在个别时候可能需要查看当前最新的事务 id,以便做一些业务逻辑上的判断(例如利用事务 id 变化以及前后时差,统计每次事务的响应时长等用途)。通常地,... [阅读全文]
  • 如何优雅、安全的关闭MySQL进程

    前言本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 mysql 实例,对这个过程不甚清楚的同学可以参考下。关闭过程1、发起 shutdown... [阅读全文]
  • 详解MySQL8.0​ 字典表增强

    详解MySQL8.0​ 字典表增强

    mysql中数据字典是数据库重要的组成部分之一,information_schema首次引入于mysql 5.0,作为一种从正在运行的mysql服务器检索元数据... [阅读全文]
  • 简述MySQL InnoDB存储引擎

    前言:存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,... [阅读全文]
验证码:
移动技术网