的myisam,innodb中,堆(内存),ndb
貌似一般都是使用innodb的
mysql存储引擎:myisam表中,innodb,bdb,memory,merge,实施例,ndbcluster,archive,csv,blackhole,federated等,其中innodb和bdb事务安全表,其他存储引擎非事务安全表。
最常用的存储引擎:
1.myisam
mysql的默认存储引擎来创建创建一个新表,新表的存储引擎不指定,则默认使用myisam。每个myisam分成三个文件存储在磁盘上。相同的文件名和表名的扩展。的frm(存储表定义),myd(mydata存储数据)。
myi(myindex的,存储索引)。数据文件和索引文件可以被放置在不同的目录中,均匀地分布io,获得更快的。
2.innodb的存储引擎,提供了交易的安全性具有提交,回滚和崩溃恢复能力。不过对比在myisam,innodb的写处理效率和存储引擎会占用更多的磁盘空间来保存数据和索引。
不知道你
MySQL常见的三种存储引擎为InnoDB、MyISAM和MEMORY。其区别体现在事务安全、存储限制、空间使用、内存使用、插入数据的速度和对外键的支持。具体如下:
1、事务安全:
InnoDB支持事务安全,MyISAM和MEMORY两个不支持。
2、存储限制:
InnoDB有64TB的存储限制,MyISAM和MEMORY要是具体情况而定。
3、空间使用:
InnoDB对空间使用程度较高,MyISAM和MEMORY对空间使用程度较低。
4、内存使用:
InnoDB和MEMORY对内存使用程度较高,MyISAM对内存使用程度较低。
5、插入数据的速度:
InnoDB插入数据的速度较低,MyISAM和MEMORY插入数据的速度较高。
6、对外键的支持:
InnoDB对外键支持情况较好,MyISAM和MEMORY两个不支持外键。
参考资料:百度百科—MySQL存储引擎
因此,ISAM执行读取 *** 作的速度很快,而且不占用大量的内存和存储资源。ISAM的两个主要不足之处在于,它不支持事务处理,也不能够容错:如果你的硬盘崩溃了,那么数据文件就无法恢复了。如果你正在把ISAM用在关键任务应用程序里,那就必须经常备份你所有的实时数据,通过其复制特性,MySQL(和PHP搭配之最佳组合)能够支持这样的备份应用程序。MyISAMMyISAM是MySQL(和PHP搭配之最佳组合)的ISAM扩展格式和缺省的MySQL数据库引擎。除了提供ISAM里所没有的索引和字段管理的大量功能,MyISAM还使用一种表格锁定的机制,来优化多个并发的读写 *** 作。其代价是你需要经常运行OPTIMIZE TABLE命令,来恢复被更新机制所浪费的空间。MyISAM还有一些有用的扩展,例如用来修复MySQL数据库文件的MyISAMChk工具和用来恢复浪费空间的MyISAMPack工具。HEAPHEAP允许只驻留在内存里的临时表格。驻留在内存里让HEAP要比ISAM和MyISAM都快,但是它所管理的数据是不稳定的,而且如果在关机之前没有进行保存,那么所有的数据都会丢失。在数据行被删除的时候,HEAP也不会浪费大量的空间。HEAP表格在你需要使用SELECT表达式来选择和 *** 控数据的时候非常有用。要记住,在用完表格之后就删除表格。让我再重复一遍:在你用完表格之后,不要忘记删除表格。InnoDB和Berkley DBInnoDB和Berkley DB(BDB)数据库引擎都是造就MySQL(和PHP搭配之最佳组合)灵活性的技术的直接产品,这项技术就是MySQL(和PHP搭配之最佳组合)++ API。在使用MySQL(和PHP搭配之最佳组合)的时候,你所面对的每一个挑战几乎都源于ISAM和MyISAM数据库引擎不支持事务处理也不支持外来键。尽管要比ISAM和MyISAM引擎慢很多,但是InnoDB和BDB包括了对事务处理和外来键的支持,这两点都是前两个引擎所没有的。如前所述源码天空,如果你的设计需要这些特性中的一者或者两者,那你就要被迫使用后两个引擎中的一个了。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)