事务
(1)什么是事务?
为了完成某个业务对数据库完成一系列操作,要么全部成功,要么全部失败
(2)事务特点
1.原子性:指的是事务所涉及的各个操作要么全部成功,要么全部失败.
2.一致性:事务完成之后,不能有非法的数据写入数据库
3.隔离性:多个事务可以在一定程度上并发执行,可以在一定程度上不受影响.
4.持久性:事务完成之后,数据要写入到数据库(也就是数据要保存到硬盘上)
(3)隔离级别
(1)读未提交:一个事务可以读取到另外一个事务尚未提交的数据,既发声了"脏读",此外,该隔离级别还可能
产生"不可重复读取"和"幻影重复读取"
(2)读已提交:一个事务只能读取到另外一个事务已经提交的数据,该隔离级别解决了"脏读"问题,但是有可能
产生"不可重复读取"和"幻影重复读取"
(3)可重复读取
在同一个事务当中,多次查询(查询的条件不变),得到的结果是一样的,该隔离级别解决了,"脏读"的问题
,"不可重复读取",但是有可能"幻影读取的问题"
(4)序列化:在多个事务不能并发执行了,只能一个一个执行(排队),该隔离级别解决了"脏读","不可重复读取",
"幻影读取"的问题,但是,程序的并发性没有了,也就说程序的整体的性能会下降(安全性强!)
总结:
a.隔离级别是从低到高依次是"读未提交"->"读已提交"->"可重复读取"->"序列化".
b.隔离级别越高,并发性能越低
c.在实际应用中,要依据业务需要设置响应的隔离级别,一般来说,对数据一致性要求不高的场合,可以将事务
隔离级别设置的低一些,常见的是设置"读已提交",反之,应该高一些,比如银行,经常隔离级别设置为序列化