MySQL存储引擎
选择合适的存储引擎,对数据库设计有很大帮助,例如怎样的场景用什么存储引擎更加合适。
MyISAM
特点
- 不支持事务
- 支持全文索引
- 主键索引和二级索引完全一样都是B+树的数据结构,只有是否唯一的区别
- 数据文件和索引文件分开存储
在MyISAM存储引擎下创建表,会创建如下三个文件:
- tb_demo.frm,存储表定义;
- tb_demo.MYD,存储数据;
- tb_demo.MYI,存储索引。
适用场景
- 筛选大量数据是非常迅速
- 并发插入特性,允许同时选择和插入数据
InnoDB
特点
- 为用户非常大的数据提供强大的解决方案
- 支持事务
- 适合处理多重并发的更新请求
- 自动灾难恢复。与其它存储引擎不同,InnoDB表能够自动从灾难中恢复
- 外键约束。MySQL支持外键的存储引擎只有InnoDB
- 支持自动增加列AUTO_INCREMENT属性
- 行锁,对索引加锁,而不是对数据加锁
适用场景
- 如果需要事务支持,并且有较高的并发读取频率,InnoDB是不错的选择
NDBCluster
特点
- 分布式:分布式存储引擎,可以由多个NDBCluster存储引擎组成集群分别存放整体数据的一部分,解决了单点故障问题
- 支持事务:和Innodb一样,支持事务
- 可与mysqld不在一台主机:可以和mysqld分开存在于独立的主机上,然后通过网络和mysqld通信交互
- 内存需求量巨大:新版本索引以及被索引的数据必须存放在内存中,老版本所有数据和索引必须存在与内存中
- 行锁
- 高吞吐量和低延迟,因为使用内存
- 扩展性好,支持在线扩容
- 快速的自动失效切换
- 支持nosql
- 符合 ACID 要求的事务型数据库
- 自动数据分片,这样就没必要做分区了
缺点
- 部署、管理、配置很复杂
- 占用内存大
- 内存中的数据,有无丢失风险
适用场景
- 大容量 OLTP
- 实时分析
- 支持欺诈检测的电子商务和金融交易
- 移动和小额支付
- 会话管理和缓存
- 串流派送、分析和推荐
- 内容管理和交付
- 大型多人在线游戏
- 通信和位置服务
- 使用者/用户资料管理和授权
Memory
特点
- Memory为了最快的响应时间,将数据存储在内存中,性能很高。但当mysqld守护进程崩溃时,所有的Memory数据都会丢失。
- 要求数据的长度不变,所以不能使用BLOB和TEXT这样的长度可变的数据类型,VARCHAR是一种长度可变的类型,但因为它在MySQL内部当做长度固定不变的CHAR类型。
- 每一个memory表有一个类似于.frm文件存储表结构,数据在内存中,这样速度快。
- 每个索引用Hash索引,查找速度比B-+Tree都快,如果想用BTree,在创建时引用。
- 因为数据在内存中,所以一般只保存一次性或不重要的数据。
适用场景
- 目标数据较小,而且被非常频繁地访问
- 如果数据是临时的,而且要求必须立即可用,那么就可以存放在内存表中
- 存储在Memory表中的数据如果突然丢失,不会对应用服务产生实质的负面影响
Memory同时支持散列索引和B树索引。B树索引的优于散列索引的是,可以使用部分查询和通配查询,也可以使用<、>和>=等操作符方便数据挖掘。散列索引进行“相等比较”非常快,但是对“范围比较”的速度就慢多了,因此散列索引值适合使用在=和<>的操作符中,不适合在<或>操作符中,也同样不适合用在order by子句中。
Merge
特点
Merge表就是几个相同MyISAM表的聚合器;Merge表中并没有数据,对Merge类型的表可以进行查询、更新、删除操作,这些操作实际上是对内部的MyISAM表进行操作。Merge存储引擎的使用场景。
适用场景
对于服务器日志这种信息,一般常用的存储策略是将数据分成很多表,每个名称与特定的时间端相关。例如:可以用12个相同的表来存储服务器日志数据,每个表用对应各个月份的名字来命名。当有必要基于所有12个日志表的数据来生成报表,这意味着需要编写并更新多表查询,以反映这些表中的信息。与其编写这些可能出现错误的查询,不如将这些表合并起来使用一条查询,之后再删除Merge表,而不影响原来的数据,删除Merge表只是删除Merge表的定义,对内部的表没有任何影响。
Archive
特点
- 只是支持基本的插入和查询
- MySQL之后支持索引
适用场景
Archive拥有很好的压缩机制,它使用zlib压缩库,在记录被请求时会实时压缩,所以它经常被用来当做仓库使用。
BDB
BDB存储引擎全称为BerkeleyDB存储引擎,和Innodb一样,也不是MySQL自己开发实现的一个存储引擎,而是由SleepycatSoftware所提供,当然,也是开源存储引擎,同样支持事务安全。
Federated
FEDERATED存储引擎所实现的功能,和Oracle的DBLINK基本相似,主要用来提供对远程MySQL服务器上面的数据的访问接口。如果我们使用源码编译来安装MySQL,那么必须手工指定启用FEDERATED存储引擎才行,因为MySQL默认是不起用该存储引擎的。
BlackHole
BLACKHOLE存储引擎是一个非常有意思的存储引擎,功能恰如其名,就是一个“黑洞”。就像我们unix系统下面的“/dev/null”设备一样,不管我们写入任何信息,都是有去无回。
CSV
CSV存储引擎实际上操作的就是一个标准的CSV文件,他不支持索引。起主要用途就是大家有些时候可能会需要通过数据库中的数据导出成一份报表文件,而CSV文件是很多软件都支持的一种较为标准的格式,所以我们可以通过先在数据库中建立一张CVS表,然后将生成的报表信息插入到该表,即可得到一份CSV报表文件了。
存储引擎的比较:
存储引擎的问题:
1. 怎么查看当前数据库的引擎
show engines
2. 如何选择存储引擎,根据下面几方面考虑
1)是否支持事务,是否支持外键(InnoDB)
2)是否需要使用热备
3)崩溃恢复,能否接受崩溃(InnoDB)
4)是否需要全文索引(MyISAM)
5)是否大数据量(InnoDB)
6)如果读多写少(MyISAM)
http://www.jb51.net/article/55849.htm
http://blog.csdn.net/zhangyuan19880606/article/details/51217952
http://www.cnblogs.com/luxiaoxun/p/4694144.html
相关推荐
实验的主要目的是熟悉 MySQL 存储引擎的概念,掌握 MySQL 存储引擎的设置和特点,并了解 MySQL 存储引擎的使用方法。 二、实验内容 实验内容包括: 1. 查看 MySQL 8.0 支持的存储引擎,指出各个存储引擎相同点和...
MySQL 存储引擎详解 ...不同的存储引擎都有其特点和优缺,了解 MySQL 存储引擎的特点和优缺是非常重要的,因为它们直接影响着数据库的性能和稳定性。选择合适的存储引擎可以提高应用的性能和稳定性。
并给出了大量最佳实践,希望通过《MySQL内核:InnoDB存储引擎 卷1》帮助用户真正了解一个数据库存储引擎的开发。, 《MySQL内核:InnoDB存储引擎 卷1》可以成为带领读者进入数据库存储引擎的内核开发,帮助那些从事...
深入学习《MySQL内核:InnoDB存储引擎 卷1》,读者可以了解到InnoDB的内部工作机制,如如何处理B+树索引、事务的提交与回滚、锁的实现以及内存管理等内容,这对于优化数据库性能、解决并发问题、设计高效的数据模型...
### MySQL存储引擎比较 #### 一、概述 MySQL是一款广泛使用的开源关系型数据库管理系统,在不同的应用场景下,选择合适的存储引擎至关重要。MySQL支持多种存储引擎,每种存储引擎都有其独特的特性和适用场景。本文...
在阅读《MySQL技术内幕:InnoDB存储引擎》时,读者可以了解InnoDB的历史和背景,了解InnoDB的发展历程和特点。接着,读者可以详细地了解InnoDB的体系结构,包括InnoDB的内存架构、磁盘I/O、事务处理等。这些内容不仅...
MySQL是世界上最流行的关系型数据库管理系统之一,其强大的功能和灵活性主要得益于它支持多种存储引擎。在MySQL课程中,深入理解存储引擎是至关重要的,因为不同的存储引擎有着不同的特性和适用场景,这直接影响到...
接下来,我们将详细介绍几种常用的MySQL存储引擎: - **MyISAM**:这是MySQL的默认存储引擎之一,适用于Web应用和数据仓库环境。MyISAM不支持事务处理,但它提供了较快的读写速度,非常适合于读多写少的应用场景。 ...
MySQL数据库系统支持多种表类型,也称为存储引擎。这些存储引擎各具特色,适用于不同的应用场景,从而满足用户在性能、可扩展性、事务安全性等...了解并合理利用这些存储引擎特性,能够优化MySQL数据库的性能和效率。
《MySQL技术内幕_InnoDB存储引擎_姜承尧_第2版》是一本深入探讨MySQL数据库中InnoDB存储引擎的专业书籍。作者姜承尧是数据库领域的知名专家,他的这部著作详细阐述了InnoDB引擎的核心概念、设计原理以及实际操作技巧...
通过本文的详细介绍,我们深入了解了MySQL存储引擎的重要性以及不同存储引擎的特点和应用场景。选择合适的存储引擎对于优化MySQL数据库性能和确保数据一致性至关重要。希望本文能够帮助您更好地理解和运用MySQL存储...
### MySQL存储引擎配置与SQL查询 #### 一、MySQL存储引擎的配置 在MySQL数据库管理系统中,存储引擎是用于组织和管理数据的方式。不同的存储引擎提供了不同的特性,例如事务处理能力、索引类型等。因此,了解如何...
MySQL存储引擎源码学习是一个深度探索数据库管理系统内部机制的重要主题,尤其对于想要深入了解MySQL数据库运行原理的开发者来说,这是不可或缺的知识。MySQL支持多种存储引擎,每个引擎都有其独特的特性和适用场景...
总结来说,这个文档详细介绍了如何在Linux环境下搭建PXC集群,配置MySQL存储引擎,并进行相关的测试和优化。通过这些案例,读者可以学习到如何在实际环境中实现高可用性和数据一致性,这对于大型应用和分布式系统的...
了解这些存储引擎的特性和适用场景,对于数据库管理员和开发者来说至关重要,可以根据应用需求选择合适的引擎,从而实现最佳的性能和可靠性。在设计数据库时,合理利用MySQL的存储引擎特性,可以极大地提升系统性能...
MySQL 数据库存储引擎探析 MySQL 是一个流行的开源关系型数据库管理系统(RDBMS),广泛应用于各种业务场景。它支持多种存储引擎,每种引擎都有其独特的特性和适用场景。本文将深入探讨 MySQL 数据库中常用的存储...
MySQL存储引擎是数据库管理系统的核心组成部分,它决定了数据的存储方式、事务处理机制、索引类型以及其他关键特性。MySQL提供多种存储引擎,每种引擎针对不同的数据库应用场景进行了优化。以下是几种常见的MySQL...
了解并选择合适的存储引擎对于优化MySQL数据库的性能至关重要。比如,如果应用程序需要事务处理和高并发,InnoDB可能是最佳选择;而对于读取频繁、写入较少的场景,可以选择Memory引擎以提高读取速度。选择正确的...
通过本书的阅读和学习,读者将深入了解 MySQL 的核心技术和 InnoDB 存储引擎的关键原理,同时掌握一些实战技巧,从而更好地应用 MySQL 技术进行数据管理。本书的结构分为三个部分。第一部分介绍 MySQL 技术内幕,...
本篇文章旨在深入探讨 MySQL 中的一个关键概念——存储引擎,并详细介绍如何查看当前使用的存储引擎。通过本文的学习,读者将能够掌握有关存储引擎的基本概念,以及如何通过多种方法来确定当前使用的存储引擎。 ###...