MySQL存储引擎介绍

发布时间:2024年01月18日

1. InnoDB(默认的存储引擎):

事务支持: InnoDB 支持事务,是 MySQL 默认的存储引擎。
行级锁定: InnoDB 提供行级锁定,有助于提高并发性能。
外键支持: InnoDB 支持外键,可以确保数据的完整性。
崩溃恢复: InnoDB 支持崩溃恢复,具有高度可靠性。

2. MyISAM:

非事务性: MyISAM 不支持事务,适合用于读密集型应用。
表级锁定: MyISAM 使用表级锁定,可能导致并发性能较低。
全文索引: MyISAM 支持全文索引,适用于搜索和文本匹配。

3. MEMORY:

存储在内存中: MEMORY 存储引擎将表的数据存储在内存中,速度较快。
临时表: 适用于存储临时数据或作为临时表的存储引擎。
数据丢失: 重启 MySQL 或发生崩溃时,存储在 MEMORY 表中的数据会丢失。
NDB Cluster:

4. 分布式存储:

NDB Cluster 是一个分布式存储引擎,适用于 MySQL Cluster。
高可用性: 具有高可用性和容错性,支持自动分区和数据复制。
ARCHIVE:

5. 归档存储:

ARCHIVE 存储引擎用于归档数据,适用于存储大量历史数据。
只读: ARCHIVE 表是只读的,不支持索引。
CSV:

6. CSV 格式:

CSV 存储引擎将数据以 CSV 格式存储,适用于数据交换。
只读: CSV 表是只读的,不支持索引。

7. BLACKHOLE:

数据传递: BLACKHOLE 存储引擎接收数据但不存储,适用于数据传递和复制。

8. Federated:

分布式数据库: Federated 存储引擎用于连接到其他 MySQL 服务器,实现分布式数据库。
选择合适的存储引擎取决于应用的性能需求、事务要求和数据特性。常见的选择是 InnoDB,因为它提供了事务支持和高度可靠的特性。

9. Innodb 和MyISAM的区别

InnoDB 和 MyISAM 是 MySQL 中两种常用的存储引擎,它们在设计和功能上有一些区别。以下是它们的主要区别:

  • 事务支持:
    InnoDB: 支持事务处理,具有ACID(原子性、一致性、隔离性、持久性)属性。适用于需要事务支持的应用,如银行系统、在线购物等。
    MyISAM: 不支持事务处理。适用于读密集型的应用,如博客、新闻网站等。
    锁定级别:

  • InnoDB: 使用行级锁定,可以提高并发性能,允许多个事务同时对同一表的不同行进行操作。
    MyISAM: 使用表级锁定,可能导致并发性能较低,因为在写操作时会锁定整个表,阻塞其他写操作。
    外键支持:

  • InnoDB: 支持外键约束,确保数据的完整性。可以定义和使用外键,进行级联操作。
    MyISAM: 不支持外键约束,无法定义和使用外键。
    全文索引:
    InnoDB: 支持全文索引,可以用于更高级的文本搜索和匹配。
    MyISAM: 有较好的全文索引支持,适用于需要进行全文搜索的应用。
    崩溃恢复:

  • InnoDB: 具有崩溃恢复的能力,可以在发生崩溃时恢复数据。
    MyISAM: 不具备崩溃恢复的能力,容易在发生崩溃时造成数据损失。
    表空间和缓存:

  • InnoDB: 数据和索引存储在同一个表空间中,适合处理大量数据。支持缓冲池概念,用于管理内存中的数据和索引。
    MyISAM: 数据和索引分别存储在不同的文件中,可能导致磁盘 I/O 较多。不支持像 InnoDB 那样的缓冲池机制。
    性能:

  • InnoDB: 适用于写入和读取操作都较为频繁的应用,因为它支持并发的写入操作和事务处理。
    MyISAM: 适用于以读操作为主的应用,因为它在读取性能上可能更优,但在写入和事务方面性能相对较差。

在实际应用中,如果需要处理并发的写入操作、事务处理和保证数据完整性,通常推荐使用 InnoDB 存储引擎MyISAM 适用于读密集型的应用,对于只需要基本的读取和查询操作的场景可能更为合适。因此,在选择存储引擎时,需根据应用的具体需求来做出合适的选择。

文章来源:https://blog.csdn.net/feichang_notlike3/article/details/135661870
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。