数据库避免脏读,幻读

一、脏读

       一个事务读取到了另外一个事务没有提交的数据

      详细解释:脏读就是指:当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。因为这个数据是还没有提交的数据,那么另外一个事务读到的这个数据是脏数据,依据脏数据所做的操作可能是不正确的。

     解决: 

    修改时加排他锁,直到事务提交后才释放,

  读取时加共享锁,读取完释放事务1读取数据时加上共享锁后(这样在事务1读取数据的过程中,其它事务就不会修改该数据的),不允许任何事务操作该数据,只能读取,之后1如果有更新操作,那么会转换为排他锁,其他事务更无权参与进来读写,这样就防止了脏读问题。

       但是当事务1读取数据过程中,有可能其他事务也读取到了该数据,读取完毕后共享锁释放,此时事务1修改数据,修改完毕提交事务,其他事务再次读取数据时候发现数据不一致,就会出现不可重复都问题,所以这样不能避免不可重复读问题。

二、不可重复读/幻读

     不可重复读:在统一事务中,两次读取同一数据,得到内容不同

   幻读: 再同一事务中,用同样的操作读取了两次,得到的纪录数不相同

 解决:

  读取数据时加共享锁,写数据时加排他锁,都是事务提交才释放锁。读取时候不允许其他事务修改该数据,不管数据在事务过程中读取多少次,数据都是一致的,避免了不可重复读问题

   

 

posted @ 2022-02-08 18:30  探索的动机  阅读(390)  评论(0编辑  收藏  举报