Rumah  >  Artikel  >  pangkalan data  >  高性能MySQL-存储引擎MyISAM与InnoDB基本区别介绍

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

黄舟
黄舟asal
2017-03-15 17:19:251657semak imbas


这篇博文主要是总结关于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条件时,两种表的操作是一样的。

Atas ialah kandungan terperinci 高性能MySQL-存储引擎MyISAM与InnoDB基本区别介绍. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn