`
jsntghf
  • 浏览: 2532973 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

MyISAM和InnoDB的异同

阅读更多

InnoDB和MyISAM是在使用MySQL时最常用的两个表类型,各有优缺点,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。MyISAM类型的表强调的是性能,其执行速度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持以及外部键等高级数据库功能。

 

以下是一些细节和具体实现的差别:

1. InnoDB不支持FULLTEXT类型的索引。

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

4. DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。

5. LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用额外的InnoDB特性(例如外键)的表不适用。

 

另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”任何一种表都不是万能的,只有恰当的针对业务类型来选择合适的表类型,才能最大的发挥MySQL的性能优势。

 

InnoDB被用来在众多需要高性能的大型数据库站点上产生。著名的Internet新闻站点Slashdot.org运行在InnoDB上。Mytrix, Inc.在InnoDB上存储超过1TB的数据,还有一些其它站点在InnoDB上处理平均每秒800次插入/更新的负荷。

 

在技术上,InnoDB 是一套放在 MySQL 后台的完整数据库系统,InnoDB 在主内存中建立其专用的缓冲池用于高速缓冲数据和索引。

 

InnoDB 把数据和索引存放在表空间里,可能包含多个文件,这与其它的不一样,举例来说,在MyISAM 中,表被存放在单独的文件中。InnoDB 表的大小只受限于操作系统的文件大小,可也可以每个表使用各自独立的表空间,只需要启用选项innodb_file_per_table。

 

http://www.innodb.com/上可以找到InnoDB最新的信息。InnoDB手册的最新版本总是被放置在那里,并且在那里可以得到InnoDB 的商业许可以及支持。

 

MyIASM是IASM表的新版本,有如下扩展:
 
    1. NULL列索引。 
    2. 对变长行比ISAM表有更少的碎片。 
    3. 支持大文件。 
    4. 更好的索引压缩。 
    5. 更好的键码统计分布。 
    6. 更好和更快的auto_increment处理。

    7. 二进制层次的可移植性。 

分享到:
评论

相关推荐

    Mysql 的存储引擎,myisam和innodb的区别

    本文主要探讨两种最常用的存储引擎——MyISAM和InnoDB之间的关键区别。 MyISAM是MySQL早期的默认存储引擎,它以高效读取和快速查询闻名。MyISAM采用表级锁定,这意味着在整个操作过程中,如果一个用户对表进行读取...

    sql 面试题.rar

    6. **存储引擎**:了解常见的存储引擎,如MyISAM和InnoDB的区别,MyISAM适用于读取频繁的场景,而InnoDB支持事务处理,更安全。此外,还可以涉及其他存储引擎,如Memory、NDB Cluster等。 7. **SQL性能调优**:理解...

    数据库面试题

    - InnoDB与MyISAM引擎的区别在哪里?为什么InnoDB更适合事务处理? - 解释MySQL的分区策略,如范围分区、列表分区和哈希分区。 - MySQL的事务隔离级别有哪些?如何通过设置`transaction_isolation`来改变隔离级别...

    SqlServer,Oracle,MySql数据库结构相互对比同步.rar

    综上所述,理解SQL Server、Oracle和MySQL的数据库结构及异同,有助于在选择数据库系统时作出决策,并为数据同步提供有效策略。对于开发人员来说,掌握这些知识能更好地管理和维护多数据库环境下的应用。

    MSSQLMySQLOracle三大主流数据库快速上手视频.zip

    - 学习内容:安装MySQL服务器,使用MySQL Workbench进行数据库设计和管理,学习SQL语法,理解存储引擎如InnoDB和MyISAM的区别,以及如何进行性能优化。 3. **Oracle** - Oracle数据库是全球最大的商业数据库软件...

    MySQL参考手册(个人整理)

    8. **存储引擎**:MySQL支持多种存储引擎,如InnoDB(支持事务和行级锁定)、MyISAM(快速读取但不支持事务)等,每种引擎有其特性和适用场景。 9. **备份与恢复**:讲解如何备份和恢复MySQL数据库,以防止数据丢失...

    腾讯PHP开发工程师笔试试卷

    包括InnoDB、MyISAM等,InnoDB支持事务,MyISAM速度快但不支持。 9. 字段类型: 如VARCHAR(255)变长,CHAR(255)定长,INT整数,BLOB大对象等,存储长度和空间占用各异。 以上只是部分要点,具体题目可能需要更...

    SQL_learning:МоитестовыезаданиянасобеседованияSQL Oracle | Java MySQL

    学习MySQL,你需要掌握的基础包括SQL标准语法、存储引擎的区别(如InnoDB和MyISAM)、触发器、存储过程、事务处理、视图、备份与恢复,以及性能优化技巧。 标题中提到的"Java MySQL"暗示了数据库连接和操作在Java...

Global site tag (gtag.js) - Google Analytics