事务的四大特征:
ACID:Atomic(原子性)、Consistent(一致性)、Isolated(独立性)、Durable (持久性)
MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关:
sql代码
1. MyISAM:不支持事务,用于只读程序提高性能
2. InnoDB:支持ACID事务、行级锁、并发
3. Berkeley DB:支持事务
事务隔离级别标准:
ANSI(美国国家标准学会)标准定义了4个隔离级别,MySQL的InnoDB都支持:
sql代码
1. READ UNCOMMITTED:最低级别的隔离,通常又称为dirty read,它允许一个事务读取还没commit的数据,这样可能会提高性能,但是dirty read可能不是我们想要的
2. READ COMMITTED:在一个事务中只允许已经commit的记录可见,如果session中select还在查询中,另一session此时insert一条记录,则新添加的数据不可见
3. REPEATABLE READ:在一个事务开始后,其他session对数据库的修改在本事务中不可见,直到本事务commit或rollback。在一个事务中重复select的结果一样,除非本事务中update数据库。
4. SERIALIZABLE:最高级别的隔离,只允许事务串行执行。为了达到此目的,数据库会锁住每行已经读取的记录,其他session不能修改数据直到前一事务结束,事务commit或取消时才释放锁。