事务特性及脏读、不可重复读、幻读(虚读)

事务是指逻辑上的一组操作,这组操作要么全部成功,要么全部失败。

事务的特性(ACID):

原子性(A):事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

一致性(C):事务前后数据的完整性必须保持一致。例:A:200,B:200,A、B之间无论怎么交换,最终都要保证和是400。

隔离性(I):多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离。如果不考虑隔离性,会引发安全问题如下:脏读不可重复读幻读(虚读)。

脏读:一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。

不可重复读:在同一事务中,多次读取同一数据返回的结果有所不同,读到了之前的数据后又读到了其他事务已经提交的更新的数据。

幻读(虚读):一个事务读取了几行记录后,另一个事务插入(insert)一些记录幻读就发生了。再后来的查询中,第一个事务就会发现有些原来没有的记录。

因此需要设置事务隔离级别(四种)。


如果隔离级别设置成DEFAULT,那么底层数据库用什么,DEFAULT就表示什么隔离级别。

Mysql默认采用REPEATABLE_READ隔离级别。

Oracle默认采用READ_COMMITTED隔离级别。

持久性(D):一个事务一旦被提交,他对数据库中数据的改变是永久性的,即使数据库发生故障也不应该对其有影响。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章