studyaccount_02

mybatis中的事务

什么是事务

事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。事务可大可小,在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。

事务的四大特性ACID

  • 原子性(Atomicity):事务是数据库逻辑单元,事务里的内容要么全部成功要么都不成功。

  • 一致性(Consistency):事务执行的结果必须是使数据库数据从一个一致性状态变到另外一种一致性状态。当事务执行成功后就说数据库处于一致性状态。如果在执行过程中发生错误,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这是数据库就处于不一致状态。

  • 隔离性(Isolation):隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。
      即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。

  • 持久性(Durability):事务结束,数据就持久化到数据库。

不考虑隔离性会产生的3个问题

  • 脏读:一个事务读到另一个事务未提交的数据。
    如:转账问题:a转b100;首先执行b+100;这是另一个事务读取b的钱多了100,但是只要原来的事务不提交,b就会回滚,这就是脏读。

  • 不可重复读:在一个事务里面读取了两次某个数据,读出来的数据不一致
    不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,被另一个事务修改并提交了。

  例如事务T1在读取某一数据,而事务T2立马修改了这个数据并且提交事务给数据库,事务T1再次读取该数据就得到了不同的结果,发送了不可重复读。

  不可重复读和脏读的区别是,脏读是某一事务读取了另一个事务未提交的脏数据,而不可重复读则是读取了前一事务提交的数据。

  • 幻读:在一个事务里面的操作中发现了未被操作的数据
    幻读是事务非独立执行时发生的一种现象。例如事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作,这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚刚修改的数据,会发现还有一行没有修改,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。

  幻读和不可重复读都是读取了另一条已经提交的事务(这点就脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。

解决办法:四种隔离级别

  • 读未提交:事务未提交的数据可以读。什么问题都解决不了

  • 读已提交:读取已经提交了的数据,可以防脏读,不能防不可重复读和幻读。

  • 可重复读:读一个数据时,上锁。期间不让其他事务做删除修改操作

  • 串行化:直到一个事务的所有子事务全部结束才可以执行下一个事务。

它是通过sqlsession对象的commit方法和rollback方法实现事务的提交和回滚

posted @ 2020-05-02 00:45  XP二二不  阅读(79)  评论(0编辑  收藏  举报