您的当前位置:首页InnoDb和MyISAM的区别与优化

InnoDb和MyISAM的区别与优化

来源:锐游网
InnoDB:
	支持事务处理等
	不加锁读取
	支持外键
	支持行锁
	不支持FULLTEXT类型的索引
	不保存表的具体行数,扫描表来计算有多少行,select count(*)性能差
	DELETE 表时,是一行一行的删除
	InnoDB 把数据和索引存放在表空间里面
	跨平台可直接拷贝使用
	InnoDB中必须包含AUTO_INCREMENT类型字段的索引
	表格很难被压缩


MyISAM:
	不支持事务,回滚将造成不完全回滚,不具有原子性
	不支持外键
	支持全文搜索
	保存表的具体行数,不带where时,直接返回保存的行数,select count(*) fron table_name很快
	DELETE 表时,先drop表,然后重建表
	MyISAM 表被存放在三个文件 .frm 文件存放表格定义。 数据文件是MYD (MYData) 。 索引文件是MYI (MYIndex)引伸
	跨平台很难直接拷贝
	MyISAM中可以使AUTO_INCREMENT类型字段建立联合索引
	表格可以被压缩


选择:
	因为MyISAM相对简单所以在效率上要优于InnoDB.如果系统读多,写少。对原子性要求低。那么MyISAM最好的选择。且MyISAM恢复速度快。可直接用备份覆盖恢复。
	如果系统读少,写多的时候,尤其是并发写入高的时候。InnoDB就是首选了。
	两种类型都有自己优缺点,选择那个完全要看自己的实际类弄。





SQL优化
	开启慢查询日志,找到查询慢的语句。
	explain 语句 
		rows:mysql需要扫描的行数

因篇幅问题不能全部显示,请点此查看更多更全内容

Top