什么是事务?
事务指的程序在进行一系列严密的操作过程中,所有操作必须全部成功完成,否则在每个操作中所作的所有更改都会被撤消。
事务四个特性(ACID)
原子性(Atomicity): 操作这些指令时,要么全部执行成功,要么全部不执行。只要其中一个指令执行失败,所有的指令都执行失败,数据进行回滚,回到执行指令前的数据状态。
一致性(Consistency): 事务的执行,使数据从一个状态转换为另一个状态,但是对于整个数据的完整性保持稳定。
隔离性(Isolation): 多个事务并发开展,但是A事务与B事务之间相互不干扰。
持久性(Durability): 当事务执行完成后,数据是永久变更的。
事务隔离级别
事务的隔离级别有4种,由低到高分别为Read uncommitted 、Read committed 、Repeatable read 、Serializable 。
隔离级别的设置只对当前链接有效,Mysql的默认隔离级别是Repeatable read
- Read uncommitted(最低级别,任何情况都无法保证。)
读未提交,顾名思义,就是一个事务可以读取另一个未提交事务的数据。
- Read committed(可避免脏读的发生。)
读提交,顾名思义,就是一个事务要等另一个事务提交后才能读取数据。
- Repeatable read(可避免脏读、不可重复读的发生。)
重复读,就是在开始读取数据(事务开启)时,不再允许修改操作
- Serializable(可避免脏读、不可重复读、幻读的发生。)
序列化 ,Serializable 是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。
更多精彩内容,关注下面的微信公众号~
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。