浅谈mysql数据库存储引擎的选择
来源:互联网 发布:java pop3 编辑:程序博客网 时间:2024/05/22 06:32
上个月在面试时被问到数据库存储引擎的选择问题,不是很清楚。恰巧今日看书时看到了这一块,正好来总结下。如有不足,还望大神斧正。
(1)什么是存储引擎
Mysql中的数据都是用各种不同的技术存储在文件(或内存中的)。这些技术中的每一个技术会使用不同的存储机制、索引技巧等。我们应该根据应用的不同需求,来选择合适的存储引擎,从而改善应用的整体功能。
例如,在研究大量的临时数据,你也许需要使用内存存储引擎,内存存储引擎能够在内存中存储所有的表格数据。
或者,在并发应用中,你需要一个支持事务处理的数据库,以保证事务处理不成功时数据的回退能力。
这些不用的技术及配套的相关功能在Mysql中被称作存储引擎(也叫作表类型)。在mysql中,使用如下命令即可得到一个可用引擎的列表:
<span style="white-space:pre"></span>show engines;显示结果为:
(2)指定存储引擎的方法
可以使用很多方法指定一个要使用的存储引擎。最简单的方法是,如果需要一种能满足大多数数据库需求的存储引擎,可以在MySQL设置文件中设置一个默认的引擎类型(使用storage_engine选项),或者在启动数据库服务器时在命令行后面加上--default-storage-engine 或--default-table-type。
最直接的方式就是在创建表时指定存储引擎的类型,在create table 语句最后使用engine属性指定。
例如
CREATE TABLE mytable(id int,title char(20))ENGINE=INNODB也可以使用alter table命令来更改现有表的存储引擎,例如:
ALTER TABLE mytable ENGINE=MYISAM如果不指定的话,MySQL默认的存储引擎是MYISAM。
(3)常用存储引擎的优缺点
①ISAM
ISAM在设计之时就考虑到数据库被查询的次数要远大于更新的次数。因此,ISAM的执行读取操作的速度很快,而且不占用大量的内存和存储资源。ISAM的不足在于,它不支持事务处理,也不能容错,如果你的硬盘崩溃了,那么数据文件就无法恢复了。
②MyISAM
MyISAM是MySQL的ISAM扩展格式和默认的数据库引擎。相比于ISAM,MyISAM拥有更好的索引压缩,更好的键码统计分布。 除了提供了ISAM里所没有的索引和字段管理的大量功能,MyISAM还使用一种表格锁定的机制,来优化多个并发的读写操作。MyISAM强调了快速读写操作。
③MEMORY
MEMORY只允许驻留在内存里的临时表格中。驻留在内存里的MEMORY要比ISAM和MyISAM都快,但是它所管理的数据都是不稳定的,而且如果在关机之前没有保存,那么所有的数据都会丢失。
④InnoDB和BDB
InnoDB和BDB数据库都支持对事物处理和外来见的支持,但这两者的都比ISAM和MyISAM引擎慢很多。
(4)如何选择引擎
ISAM:执行读取操作的速度很快,而且不占用大量的内存和存储资源,但不支持事物处理,也不能容错
MyISAM:支持索引,能够实现并发的快速读取操作。
MEMORY: 只有内存存储,操作最快,但管理的数据是不稳定的.
InnoDB:支持事务和外来键,速度相对较慢。
(5)MyISAM和InnoDB对比
MyISAM类型不支持事物处理等高级处理,而InnoDB类型支持。MyISAM类型的表强调的性能,其执行速度比InnoDB类型更快,但是不提供事务支持,而InnoDB提高事务支持以及外部键等高级数据库功能。
另外,两者都可用来存储表和索引,InnoDB的索引和表存储在同一文件中,MyISAM的索引和表存储在不同文件中。InnoDB占用磁盘空间比MyISAM大,对空闲存储空间的使用不优。因此,MyISAM可大量节省磁盘空间,特别是对索引的存储上,优势巨大。
- 浅谈mysql数据库存储引擎的选择
- mysql数据库优化--存储引擎的选择
- MySQL存储引擎--存储引擎的选择
- 浅谈数据库的存储引擎
- 浅谈MySQL的存储引擎
- MYSQL-----数据库的操作及存储引擎的选择
- MySQL数据库浅谈MyISAM存储引擎
- Mysql 存储引擎的选择
- Mysql存储引擎的选择
- MySQL存储引擎的选择
- MySQL存储引擎的选择
- MySQL存储引擎的选择
- mysql 存储引擎的选择
- mysql存储引擎的选择
- MySQL存储引擎的选择
- mysql数据库优化--(4)设计 存储引擎的选择
- MySQL之浅谈MySQL的存储引擎
- 浅谈MySQL存储引擎选择 InnoDB还是MyISAM
- android declare-styleable的使用
- 网页布局
- shopNC结构介绍及Controller(图)
- IOS简单笔记
- Android获取NavigationView header中的控件
- 浅谈mysql数据库存储引擎的选择
- Android开发之裁切(拍照+相册)图像并设置头像小结
- LeetCode 35. Search Insert Position
- LeetCode 237. Delete Node in a Linked List
- LeetCode 242. Valid Anagram
- 常用排序和查询
- 动态规划 和 图遍历的结合应用
- POJ1860 Currency Exchange(最短路径)
- Linux命令详解(1) – ls