InnoDb和MyISAM的区别与优化

36 篇文章 1 订阅
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需要扫描的行数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值