• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    简述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存储引擎的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • MySQL InnoDB架构的相关总结
    • MySQL InnoDB ReplicaSet(副本集)简单介绍
    • 详解MySQL InnoDB存储引擎的内存管理
    • MySQL Innodb关键特性之插入缓冲(insert buffer)
    • MySQL InnoDB 锁的相关总结
    • 如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog
    • Mysql InnoDB的锁定机制实例详解
    • Mysql技术内幕之InnoDB锁的深入讲解
    • 修改MySQL数据库引擎为InnoDB的操作
    • MySQL InnoDB表空间加密示例详解
    • MySQL InnoDB 事务锁源码分析
    上一篇:详解MySQL8.0​ 字典表增强
    下一篇:MySQL 4种常用的主从复制架构
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    简述MySQL InnoDB存储引擎 简述,MySQL,InnoDB,存储,引擎,