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内核:InnoDB存储引擎 卷1》帮助用户真正了解一个数据库存储引擎的开发。, 《MySQL内核:InnoDB存储引擎 卷1》可以成为带领读者进入数据库存储引擎的内核开发,帮助那些从事...
此外,还包含了一些高级话题,如分区表、复制与集群、存储引擎选择等。资源包形式多样,包括文字教程、案例分析、视频教程、实践练习等,以满足不同用户的学习需求。 适用人群: 初学者:对于刚开始接触MySQL的...
主要介绍了MySQL存储引擎的相关资料,为开发时选择合适的存储引擎提供参考,感兴趣的朋友可以了解下
那我们可以理解为:MySQL 这个数据库管理系统是依靠存储引擎与存放数据的磁盘文件进行交互的。 那么 MySQL 有哪些存储引擎呢? 主要有 MyISAM、InnoDB、Memory等等。而现在互联网中,基本都是使用 InnoDB 存储引擎...
主要介绍了MySql 存储引擎和索引相关知识总结,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
这篇文章先来大概了解一下mysql的存储引擎。 参考说明:mysql5.7 查看支持的存储引擎 mysql> show engines G; *************************** 1. row *************************** Engine: InnoDB ...
1.mysql 备份数据 2.Mysql 更新数据 ...10.浅谈MySQL存储引擎选择InnoDB还是MyISAM 11.浅谈unique列上插入重复值的MySQL解决方案 12.深入了解MySQL 5.5分区功能增强.doc 13.在MySQL中操作日期和时间
文档中深入浅出的,详细描述了一条 SQL 是如何实现加锁的,包含了各种索引组合和各种隔离级别下的分析;...1、想加深对 MySQL了解,想要深入学习数据库底层的人群 2、想冲互联网大厂的人群(面试时亮点回答)
主要介绍了MySQL InnoDB存储引擎的相关资料,帮助大家更好的了解MySQL的存储引擎,感兴趣的朋友可以了解下
第三层是存储引擎层,存储引擎负责 MySQL 中数据的存储和提取。服务器通过 API 与存储引擎通信,这些接口屏蔽了不同存储引擎的差异,使得差异对上层查询过程透明。除了会解析外键定义的 InnoDB 外,存储引擎不会解析...
您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。, 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。...
您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。...
您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MySQL的不同组件是如何协同工作的。...
您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。...
此外,还包含了一些高级话题,如分区表、复制与集群、存储引擎选择等。资源包形式多样,包括文字教程、案例分析、视频教程、实践练习等,以满足不同用户的学习需求。 适用人群: 初学者:对于刚开始接触MySQL的...
第三层是存储引擎层,存储引擎负责 MySQL 中数据的存储和提取。服务器通过 API 与存储引擎通信,这些接⼝屏蔽了不同存储引擎的差异,使得差异对上层查询过程透明。除了会解析外键定义的 InnoDB 外,存储引擎不会解析...
既然Mysql有内存引擎Memory,为什么还需要Redis 随着对于Mysql的了解,我们知道Mysql有三种常用的...Memory引擎是Mysql的内存引擎,在实现上,Memory存储引擎不同于Innodb这种组织索引结构(索引即是数据,即数据存放
这个是MySQL5.5再contos6下的安装方法 MySQL 是...索引的优化策略,了解innodb和myisam存储引擎,熟悉MySQL锁机制,能熟练配置MySQL主从复制,熟练掌握explain、show profile、慢查询日志等日常SQL诊断和性能分析策略。
您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。...