Mysql(三) mysql事务和隔离级别

Mysql(三) mysql事务和隔离级别

事务是由一组SQL语句组成的逻辑处理单元

事务的特性(ACID)

  • 原子性(Atomicity):事务是不可分割的逻辑单元,事务内的操作要么全部成功,要么全部失败
  • 一致性(Consistent):对于数据而言,事务开始和完成后,必须保持一致状态。
  • 隔离性(Isolation):不同事务之间操作互不影响
  • 持久性(Durable):事务完成后,对数据的操作修改是永久性的。

如果事务并发操作会导致以下问题:

  1. 更新丢失(Lost Update)或脏写

    事务A和事务B都要对同一条记录修改,如果事务A先提交,事务B再提交,那么事务A提交的数据被覆盖,就是脏写

  2. 脏读(Dirty Reads)

    事务A对一条记录进行修改,但还未提交,此时事务B读到这条被A修改的数据,如果此时事务A回滚,那么这条数据就是脏数据

  3. 不可重复读(Non-Repeatable Reads)

    事务内读取了一条数据,一段时间后(期间另一个事务修改了这条数据并提交),再次读取这条数据,但这条数据发生了改变

  4. 幻读(Phantom Reads)

    事务两次读取数据结果集数量不一致。事务A读取到了事务B提交的新增数据

隔离级别

“脏读”、“不可重复读”和“幻读”,其实都是数据库读一致性问题,必须由数据库提供一定的事务隔离机制来解决。

隔离级别脏读不可重复读幻读
读未提交(Read uncommitted)可能可能可能
读已提交(Read committed)不可能可能可能
可重复读(Repeatable read)不可能不可能可能
可串行化读(Serializable)不可能不可能不可能
  • 读未提交:可以读到别的事务未提交的数据
  • 读已提交:只可以读到别的事务已提交的数据
  • 可重复读:解决不可重复读,事务开启后,第一次读到数据后面以后读取到的数据是一致的
  • 可串行化读:锁表,事务在读取的时候,其他事务不能新增和修改数据

常看当前数据库的事务隔离级别:

select @@transaction_isolation;

show variables like ‘tx_isolation’;

mysql默认的隔离级别是可重复读(Repeatable read)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值