数据库事务

数据库有以下几种并发问题:

  1. 第一类更新丢失


    image
  2. 脏读


    image
  3. 幻读


    image
  4. 不可重复读


    image
  5. 第二类更新丢失


    image

数据库事务隔离级别

1. READ_UNCOMMITED

  • 事务对当前被读取的数据不加锁;
  • 事务在更新某数据的瞬间(就是发生更新的瞬间),必须先对其加 行级共享锁,直到事务结束才释放。

表现:

  • 事务1读取某行记录时,事务2也能对这行记录进行读取、更新;当事务2对该记录进行更新时,事务1再次读取该记录,能读到事务2对该记录的修改版本,即使该修改尚未被提交。
  • 事务1更新某行记录时,事务2不能对这行记录做更新,直到事务1结束。

2. READ_COMMITED

  • 事务对当前被读取的数据加 行级共享锁(当读到时才加锁),一旦读完该行,立即释放该行级共享锁
  • 事务在更新某数据的瞬间(就是发生更新的瞬间),必须先对其加 行级排他锁,直到事务结束才释放。

表现:

  • 事务1读取某行记录时,事务2也能对这行记录进行读取、更新;当事务2对该记录进行更新时,事务1再次读取该记录,读到的只能是事务2对其更新前的版本,要不就是事务2提交后的版本。
  • 事务1更新某行记录时,事务2不能对这行记录做更新,直到事务1结束。

3. REPEATABLE READ

  • 事务在读取某数据的瞬间(就是开始读取的瞬间),必须先对其加 行级共享锁,直到事务结束才释放;
  • 事务在更新某数据的瞬间(就是发生更新的瞬间),必须先对其加 行级排他锁,直到事务结束才释放。

表现:

  • 事务1读取某行记录时,事务2也能对这行记录进行读取、更新;当事务2对该记录进行更新时,事务1再次读取该记录,读到的仍然是第一次读取的那个版本。
  • 事务1更新某行记录时,事务2不能对这行记录做更新,直到事务1结束。

4. SERIALIZABLE

  • 事务在读取数据时,必须先对其加 表级共享锁 ,直到事务结束才释放;
  • 事务在更新数据时,必须先对其加 表级排他锁 ,直到事务结束才释放。

表现:

  • 事务1正在读取A表中的记录时,则事务2也能读取A表,但不能对A表做更新、新增、删除,直到事务1结束。
  • 事务1正在更新A表中的记录时,则事务2不能读取A表的任意记录,更不可能对A表做更新、新增、删除,直到事务1结束。

数据库锁机制:悲观锁,乐观锁

image
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ACID 一个数据库事务通常包含了一个序列的对数据库的读/写操作。它的存在包含有以下两个目的:为数据库操作序列提供...
    德彪阅读 3,555评论 0 3
  • 什么是事务(Transaction)? 是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行...
    aluomaidi阅读 13,968评论 9 44
  • 一、最简单的例子来说明事务 “A账户向B账号汇钱”来说明事务 1、从A账号中把余额读出来。2、对A账号做减法操作。...
    AQ王浩阅读 10,961评论 0 9
  • 什么是事务 事务是并发控制的基本单位。所谓的事务,是一个操作序列,这些操作要么都执行,要么都不执行,是一个不可分割...
    是夏莞也是CiCi阅读 3,480评论 1 4
  • 【派别】文魁派 【导师】袁文魁.王玉印 【分舵】思维图腾 【舵主】林丽莉 【导图解说】中心图画的是一只手,拿了一支...
    亚洲高手阅读 3,255评论 6 2