事务的统计主要是看TPS,它是Question Per Second的缩写,代表每秒处理事务的能力。
这里的事务包括提交和回滚的两种类型。不过无论是哪一种,只有显示声明的事务才会被统计。
公式:(com_commit+com_rollock)/time
ISO和ANIS SQL标准制定了4种事务隔离级别,它们是:
1.READ UNCOMMITTED 读取为提交数据
2.READ COMMITTED 读取已提交数据
3.REPEATABLE READ 可重复读
4.SERIALIZABLE 序列化
InnoDB存储过程默认支持的界别是REPEATABLE READ。特别提示一下,因为使用Next-Key Lock算法,避免了幻读问题。
在InnoDB存储过程中,2,3,4三个级别性能差别不大,有时候甚至SERIALIZABLE 比 REPEATABLE READ还要好些。
在MySQL配置文件中,[mysqld]中可以设置事务隔离级别,例如:
[mysqld]
transaction-isolation = READ-COMMITTED
SERIALIZABLE隔离级别通常用于分布式事务。
在大量插入数据时,采用显示开启事务,最后来一次性提交或回滚。
这样做比自动提交的好处在于,显示开启事务提交是只写一次重做日志,自动提交则是insert多少条,就会写多少次重做日志。如果此时插入100万条,两者差别就非常巨大了。
最后建议采取显示开启事务,这不仅仅因为性能差异,还因为显示开启事务可以避免一些错误。