码迷,mamicode.com
首页 > 数据库 > 详细

Mysql的存储引擎的类型,MyISAM&InnoDB等

时间:2015-05-20 16:30:26      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:存储   mysql   innodb   myisam   

部分文字参考其他博客或者文字。
官方解释:

· MyISAM:默认的MySQL插件式存储引擎,它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。注意,通过更改STORAGE_ENGINE配置变量,能够方便地更改MySQL服务器的默认存储引擎。

· InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。

· BDB:可替代InnoDB的事务引擎,支持COMMIT、ROLLBACK和其他事务特性。

· Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。

· Merge:允许MySQL DBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。

· Archive:为大量很少引用的历史、归档、或安全审计信息的存储和检索提供了完美的解决方案。

· Federated:能够将多个分离的MySQL服务器链接起来,从多个物理服务器创建一个逻辑数据库。十分适合于分布式环境或数据集市环境。

· Cluster/NDB:MySQL的簇式数据库引擎,尤其适合于具有高性能查找要求的应用程序,这类查找需求还要求具有最高的正常工作时间和可用性。

· Other:其他存储引擎包括CSV(引用由逗号隔开的用作数据库表的文件),Blackhole(用于临时禁止对数据库的应用程序输入),以及Example引擎(可为快速创建定制的插件式存储引擎提供帮助)。

对于整个服务器或方案,可以为方案中的每个表使用不同的存储引擎,已达到需要的目标和效果。

任何一种表都不是万能的,只用恰当的针对业务类型来选择合适的表类型,才能最大的发挥MySQL的性能优势.

MyISAM&InnoDB一些细节上差别
1.InnoDB不支持FULLTEXT类型的索引。
2.InnoDB中不保存表的 具体行数,也就是说,执行select count() from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count()语句包含 where条件时,两种表的操作是一样的。
3.对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。

4.MySQL Administrator建数据库的时候,表缺省是InnoDB类型。

5.MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。 6.MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持,外键等高级数据库功能。

7.MyISAM类型的二进制数据文件可以在不同操作系统中迁移。也就是可以直接从Windows系统拷贝到linux系统中使用。

一些相关的命令
1.查看表信息,里面包括使用的引擎类型,字符编码,表结构等

mysql> show create table t1;–t1是表名

  1. 可以执行以下命令来切换非事务表到事务(数据不会丢失),innodb表比myisam表更安全:
    alter table t1 type=innodb;–t1是表名

  2. innodb表不能用repair table命令和myisamchk -r table_name
    但可以用check table t1,以及mysqlcheck [OPTIONS] database [tables]

  3. 启动mysql数据库的命令行中添加了以下参数可以使新发布的mysql数据表都默认为使用事务(
    只影响到create语句。)
    –default-table-type=InnoDB

  4. 临时改变默认表类型可以用:
    set table_type=InnoDB;

Mysql的存储引擎的类型,MyISAM&InnoDB等

标签:存储   mysql   innodb   myisam   

原文地址:http://blog.csdn.net/ffm83/article/details/45870657

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!