简单干净的网站,创办免费企业网站,网站什么做,品展示设计网站一般来说#xff0c;MySQL有以下几种引擎#xff1a;ISAM、MyISAM、HEAP、InnoDB和Berkley(BDB)。注意#xff1a;不同的版本支持的引擎是有差异的。当然啦#xff0c;如果你感觉自己的确技术高超#xff0c;你还能够使用MySQL来创建自己的数据库引擎#xff0c;这个已经…一般来说MySQL有以下几种引擎ISAM、MyISAM、HEAP、InnoDB和Berkley(BDB)。注意不同的版本支持的引擎是有差异的。当然啦如果你感觉自己的确技术高超你还能够使用MySQL来创建自己的数据库引擎这个已经out of my knowledge牛人可以参照MySQL API帮助来实现。下面逐一叙述这5种引擎各自的特性ISAMISAM是一个定义明确且历经时间考验的数据表格管理方法它在设计之时就考虑到数据库被查询的次数要远大于更新的次数。因此ISAM执行读取操作的速度很快而且不占用大量的内存和存储资源。ISAM的两个主要不足之处在于它不支持事务处理也不能够容错如果你的硬盘崩溃了那么数据文件就无法恢复了。如果你正在把ISAM用在关键任务应用程序里那就必须经常备份你所有的实时数据通过其复制特性MySQL能够支持这样的备份应用程序。MyISAMMyISAM是MySQL的ISAM扩展格式和缺省的数据库引擎。除了提供ISAM里所没有的索引和字段管理的大量功能MyISAM还使用一种表格锁定的机制来优化多个并发的读写操作。其代价是你需要经常运行OPTIMIZE TABLE命令来恢复被更新机制所浪费的空间。MyISAM还有一些有用的扩展例如用来修复数据库文件的MyISAMChk工具和用来恢复浪费空间的MyISAMPack工具。MyISAM强调了快速读取操作这可能就是为什么MySQL受到了Web开发如此青睐的主要原因在Web开发中你所进行的大量数据操作都是读取操作。所以大多数虚拟主机提供商和Internet平台提供商(Internet Presence ProviderIPP)只允许使用MyISAM格式。HEAPHEAP允许只驻留在内存里的临时表格。驻留在内存里让HEAP要比ISAM和MyISAM都快但是它所管理的数据是不稳定的而且如果在关机之前没有进行保存那么所有的数据都会丢失。在数据行被删除的时候HEAP也不会浪费大量的空间。HEAP表格在你需要使用Select表达式来选择和操控数据的时候非常有用。要记住在用完表格之后就删除表格。InnoDB和Berkley DBInnoDB和Berkley DB(BDB)数据库引擎都是造就MySQL灵活性的技术的直接产品这项技术就是MySQL API。在使用MySQL的时候你所面对的每一个挑战几乎都源于ISAM和MyISAM数据库引擎不支持事务处理也不支持外来键。尽管要比ISAM和MyISAM引擎慢很多但是InnoDB和BDB包括了对事务处理和外来键的支持这两点都是前两个引擎所没有的。如前所述如果你的设计需要这些特性中的一者或者两者那你就要被迫使用后两个引擎中的一个了。认识完了这么多的引擎我们也知道了它们应该在什么情况下拿来应急那么接着我们就要学会如何来更换这些引擎了。Globle一种最简单的方法就是更改服务器配置直接将其设置成你所需要的引擎。这个在win下通过更改服务器安装目录下的mysql.ini中的default-storage-engine项即可也可以通过运行MySQL Server Instance Configuration Wizard做简单的设置。Per Table:除了全局的方法外还有一种更灵活的配置方法那就是按表来设置引擎这样我们就可以把那些需要用到事务处理的表设置成InnoDB其他设置成MyISAM,将性能提升到极致这是不是很令人兴奋呢设置方法也比较简单1、你可以在Create Table语句的最后添加扩展语句如TYPEMyISAM(或者ENGINE INNODB)来指定当前标的引擎类型。也可以用Alter语句在建立表个后进行更改。当你不清楚当前数据库中各表的引擎时可以使用SHOW TABLE STATUS FROM DBname来查看。2、使用随MySQL服务器发布同时提供的MySQL客户端来创建表在创建时可以选择使用的存储引擎。不同的引擎选择在不同的业务处理上性能将有天壤之别题外话要想服务器性能达到最佳在配置服务器时也需要好好考虑。如果是在Win下那么可以通过运行MySQL Server Instance Configuration Wizard来设置它将引导你设置当前服务器的类型等等信息。还有再有大量数据需要插入的时候可以考虑使用Insert DELAYED语句(具体语法参考MySQL手册)。当一个客户端使用Insert DELAYED时会立刻从服务器处得到一个确定。并且行被排入队列当表没有被其它线程使用时此行被插入。使用Insert DELAYED的另一个重要的好处是来自许多客户端的插入被集中在一起并被编写入一个块。这比执行许多独立的插入要快很多。当然它也有其适用范围具体参考手册。mysql5.1中文手册 http://dev.mysql.com/doc/refman/5.1/zh/index.html