Mysql 建表时指定InnoDB 或MyISAM的意义

本文对比了MySQL中InnoDB和MyISAM两种存储引擎的特性,包括事务处理、性能、操作类型的影响、锁机制、查询效率及物理结构等。InnoDB支持事务和行级锁,适合大量插入更新操作;MyISAM执行SELECT更快速,采用表级锁。此外,InnoDB的行数查询较慢,物理结构更复杂,但提供更好的auto_increment处理和MVCC机制。
摘要由CSDN通过智能技术生成
1, 事务处理
innodb 支持事务功能,myisam 不支持(包括外键等等)。
Myisam 的执行速度更快,性能更好。


2,select ,update ,insert ,delete 操作


MyISAM:如果执行大量的SELECT,MyISAM是更好的选择
InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表


3,锁机制不同


InnoDB 为行级锁,myisam 为表级锁。
注意:当数据库无法确定,所找的行时,也会变为锁定整个表。
如: update table set num = 10 where username like "%test%";


4,查询表的行数不同
MyISAM:select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含   where条件时,两种表的操作是一样的


InnoDB : InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行


5,物理结构不同


MyISAM :每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值