文章目录
数据库中的事务包含四个特性:
1.原子性
指事务包含的所有操作要么成功,要么全部失败回滚。
2.一致性
一致性是指事务执行前后是从一个一致性状态变为另一个一致性状态。比如转账事务前后两个账户中金额相加应该是一致的。
3.隔离性
隔离性是指多个用户访问数据库时候,数据库会为每个用户开启相应的事务,每个用户的操作不受其他用户所影响,即使多个并发的事务也是互相隔离。
4.持久性
持久性是指事务一旦提交,数据库中的数据就是永久性的改变,数据库发生异常也不会丢失已经回滚已经提交了的数据。
在操作数据库时,根据操作情况来划分,有以下情况:
1.脏读:
指读取了事务未提交的数据,如事务T1更新了一行记录,还未提交所做的修改,这个T2读取了更新后的数据,然后T1执行回滚操作,取消刚才的修改,所以T2所读取的行就无效,就是脏数据。
2.不可重复读:
指第一次读取的数据和第二次读取的数据有可能不一样,因为在第一次读取期间有可能有别的进行对数据进行了更新,针对的是Update语句。事务T1读取一行记录,紧接着事务T2修改了T1刚刚读取的记录,然后T1再次查询,发现与第一次读取的记录不同,这称为不可重复读。
3.幻读:
指第一次读取的数据个数和第二次读取的数据个数可能不一致,因为第一次读取期间可能发生了数据的删除或插入操作,针对Insert和Delete语句。事务T1读取一条指定where条件的语句,返回结果集。此时事务T2插入一行新记录,恰好满足T1的where条件。然后T1使用相同的条件再次查询,结果集中可以看到T2插入的记录,这条新纪录就是幻读的。
三者对比,脏读是读取了还未提交的数据,而不可重复读和幻读都是读取已经提交的事务,不可重复读是针对的同一个数据项的,幻读是针对数据这个整体的(包含数据的个数),所以可以说不可重复读是针对数据更新,幻读是针对数据的插入来说的。
针对以上这些情况,常用的数据库分出了四种隔离级别:
1. 串行化(Serializable):
最严格的一种,既可以避免脏读,又可以避免不可重复读和幻读,但是性能差
2. 可重复读(Repeatable Read):
可以避免脏读和不可重复读,不可避免幻读
3. 提交读(Read commited):
可以避免脏读,不可避免幻读和不可重复读
4. 未提交读(Read Uncommited):
可以读取未提交的事务,造成脏读,幻读,不可重复读
Mysql的默认事务隔离级别为可重复读(Repeatable read)
Oracle支持Read Commited和 Serializable,默认为提交读(Read Commited)