当前位置:Gxlcms > mysql > 高性能MySQL-存储引擎MyISAM与InnoDB基本区别介绍

高性能MySQL-存储引擎MyISAM与InnoDB基本区别介绍

时间:2021-07-01 10:21:17 帮助过:22人阅读


这篇博文主要是总结关于MyISAM与InnoDB的区别

InnoDB和MyISAM是使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定。基本的差别为:

(1)MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持事务。

(2)InnoDB支持数据行锁定;MyISAM不支持行锁定,只支持锁定整个表。这里需要注意的是InnoDB表的行锁也不是绝对的,假如在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”

(3)InnoDB支持外键,MyISAM不支持。

(4)InnoDB 中不保存表的具体行数,也就是说,执行select count() from table时,InnoDB要扫描一遍整个表来计算有多少行。但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count()语句包含 where条件时,两种表的操作是一样的。

以上就是高性能MySQL-存储引擎MyISAM与InnoDB基本区别介绍的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行