码迷,mamicode.com
首页 > 数据库 > 详细

mysql 事务学习

时间:2018-07-19 19:12:29      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:持久性   bsp   mysql 事务   一个   级别   串行化   comm   ali   分割   

1.事务

  逻辑上的一组操作,组成这组操作的各个逻辑单元要么一起成功,要么一起失败.

2.事务特性

原子性:强调事务的不可分割.
一致性:强调的是事务的执行的前后,数据的完整性要保持一致.
隔离性:一个事务的执行不应该受到其他事务的干扰.
持久性:事务一旦结束(提交/回滚)数据就持久保持到了数据库.

 

3.事务的安全性问题

 

脏读 :一个事务读到另一个事务还没有提交的数据.
不可重复读 :一个事务读到了另一个事务已经提交的update的数据,导致在当前的事务中多次查询结果不一致.
虚读/幻读 :一个事务读到另一个事务已经提交的insert的数据,导致在当前的事务中多次的查询结果不一致.

 

4.事务的隔离级别

  MYSQL隔离级别:repeatable read Oracle隔离级别:read committed  
  * read uncommitted
    现象:未提交读.脏读,不可重复读,虚读都可能发生.
    原因:在读取时是不会加锁的,但在更新数据时,对其加行级共享锁(其它事务不能更改,但可以读取,导致脏读),事务结束时释放。
  * read committed
    现象:已提交读.避免脏读.但是不可重复读和虚读有可能发生.
    原因:这种隔离级别表示读取的数据是已提交成功的,解决了脏读问题,解决方式是给写数据加行级排他锁,这样写过程是无法读取的,直到事务处理完毕才释放排他锁,给读的数据加行级共享锁,这样读的时候也是无法写的,但是一旦读完该行就释放共享锁。这种模式下虽然处理了脏读,但是并没有处理丢失更新和不可重复读的问题.
  * repeatable read
    现象:重复读.避免脏读,不可重复读.但是虚读有可能发生.
    原因:在这种隔离级别下可以重复的读取数据了,顾名思义,解决了不可重复读的问题,同时也解决了更新丢失的问题。解决办法:给写的数据加行级排他锁,事务结束释放,给读的数据加行级共享锁,事务结束后释放。这种模式还是没有处理幻读的问题
  * serializable
    现象:串行化的.避免脏读,不可重复读,虚读的发生.
    原因:事务读数据则加表级共享锁,事务写数据则加表级排他锁,幻读问题也得到了解决

5.解决

  隔离级别       产生问题

read uncommitted
            脏读
read committed
            脏读不可重复读
repeatable read
            不可重复读
serializable
            虚读/幻读

 

mysql 事务学习

标签:持久性   bsp   mysql 事务   一个   级别   串行化   comm   ali   分割   

原文地址:https://www.cnblogs.com/codeLei/p/9337476.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!