简述MySQL InnoDB存储引擎

作者:MySQL技术 时间:2024-01-28 09:26:16 

前言:

存储引擎是数据库的核心,对于 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 的内容还有很多,后面有机会的话可以多写写。

来源:https://cloud.tencent.com/developer/article/1676271

标签:MySQL,存储引擎,InnoDB
0
投稿

猜你喜欢

  • 快速掌握如何使用SQL Server来过滤数据

    2009-01-15 13:27:00
  • python logging日志打印过程解析

    2023-11-03 13:04:09
  • Django choices下拉列表绑定实例

    2023-05-06 14:08:52
  • PHP字典树(Trie树)定义与实现方法示例

    2023-11-15 00:39:50
  • python超详细实现字体反爬流程

    2022-08-30 22:39:03
  • python面向对象实现名片管理系统文件版

    2022-11-25 16:27:45
  • 高性能WEB开发 JS、CSS的合并、压缩、缓存管理

    2023-01-02 11:03:26
  • Chrome插件开发系列一:弹窗终结者开发实战

    2024-04-29 13:42:04
  • Python映射类型之dict详解

    2023-08-03 13:19:19
  • Python中使用HTMLParser解析html实例

    2023-01-17 11:47:16
  • 深入php var_dump()函数的详解

    2023-11-08 16:09:01
  • RS.GETROWS使用详解

    2008-01-16 13:21:00
  • python的random模块及加权随机算法的python实现方法

    2023-09-04 13:32:57
  • Python实现网络端口转发和重定向的方法

    2023-09-23 10:19:59
  • 使用python实现rsa算法代码

    2022-07-12 14:06:10
  • 关于python DataFrame的合并方法总结

    2022-02-02 14:13:58
  • django中使用原生sql语句的方法步骤

    2023-06-29 16:36:07
  • python画一个圣诞树实现示例

    2021-06-12 03:54:53
  • python使用mediapiple+opencv识别视频人脸的实现

    2023-06-09 08:10:17
  • vue3配置全局参数(挂载全局方法)以及组件的使用

    2023-07-02 16:45:46
  • asp之家 网络编程 m.aspxhome.com