为什么二级封锁协议不能保证可重复读,一级封锁协议不能保证可重复读和读脏数据?
一、为什么二级封锁协议不能保证可重复读
排它锁又叫写锁,事务A对数据D加了排它锁,其它任何事务都不能再对数据D加共享锁或者排它锁。也就是说A可以读取或者修改D,但是其它事务不能读也不能写,但是即使数据D加了写锁,其它事务的最基本的select语句还是可以读数据D的,因为最基本的select语句并不用申请任何锁!这个是最迷惑的地方,明白了这一点,一级封锁协议协议会读脏数据就很好理解了。
事务A对数据D=1加了排它锁,修改了数据使D=2,这个时候事务B虽然不能对数据D加任何锁,但是可以用select语句读,B读到了数据D=2,之后事务A出错,回滚D=1,那你B就读到了脏数据。
二级封锁协议规定在一级的基础上规定,事务A对数据D加了排它锁,事务B想用基本的select语句读D也必须要申请共享锁(读锁)!!,而一级是不需要的!!,所以B在事务A没结束期间都不能读数据D,这样就不会出现读脏数据了!
但是二级却不能保证可重复读,这是因为,二级规定读锁是读完就释放!!而不是事务结束才释放。比如B先对数据D=1加了读锁,读完释放了读锁,但是事务B并没有结束,这时事务A对数据D加了写锁,然后修改D=2,释放了写锁,这时,事务B再次对数据D申请读锁,读到了D=2,同一个事务,两次读取不一致,这就是二级为何不能保证可重复读!
三级就是不是读完就释放,而是事务结束才释放,这样就可保证可重复读了。
延伸阅读:
二、什么是数据库
有组织且相互关联的数据的集合称为数据库。database 是一个存储数据的应用程序。它有各种应用程序,包括 MySQL、Microsoft SQL、Oracle 等。
每个数据库都不同,因为每个公司/组织都有其结构、数据类型和约束。数据库 会定期更新,以获取有关公司的最新数据。
数据库可以手动和数字方式维护。在这个数据无处不在的时代,数字数据库是优选和使用。数据库的大小取决于组织的数据和需求。
数据库有很多种类型,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。
数据库是“按照数据结构来组织、存储和管理数据的仓库”。在经济管理的日常工作中,常常需要把某些相关的数据放进这样“仓库”,并根据管理的需要进行相应的处理。
例如,企业或事业单位的人事部门常常要把本单位职工的基本情况(职工号、姓名、年龄、性别、籍贯、工资、简历等)存放在表中,这张表就可以看成是一个数据库。
有了这个”数据仓库”就可以根据需要随时查询某职工的基本情况,也可以查询工资在某个范围内的职工人数等等。这些工作如果都能在计算机上自动进行,那的人事管理就可以达到极高的水平。
此外,在财务管理、仓库管理、生产管理中也需要建立众多的这种“数据库”,使其可以利用计算机实现财务、仓库、生产的自动化管理。
猜你喜欢LIKE
相关推荐HOT
更多>>MySQL索引为什么能让查询效率提高?
一、MySQL索引为什么能让查询效率提高DB在执行一条Sql语句的时候,默认的方式是根据搜索条件进行全表扫描。如果我们对某一字段增加索引,查询时...详情>>
2023-10-19 13:16:01什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
一、四层负载均衡(L4 proxy)四层负载均衡工作在OSI模型的传输层,由于在传输层,只有TCP/UDP协议,这两种协议中除了包含源IP、目标IP以外,还包...详情>>
2023-10-19 09:17:45为什么用navicat连接sqlserver后看不到master数据库?
一、为什么用navicat连接sqlserver后看不到master数据库在navicat的安装目录下找到sqlserver的驱动双击安装即可,现在我们就可以连接Navicat了...详情>>
2023-10-19 08:23:06mq消息积压中,突然mq挂了,或者mysql挂了,或者两个都挂了怎么处理?
一、mq消息积压中,mq挂了的处理方法如果MQ挂掉,势必会影响发消息的逻辑,MQ不像数据库,挂了就没办法进行任何操作了。MQ本身就是用于多系统解...详情>>
2023-10-19 06:18:33热门推荐
Python语言除了爬虫scrapy外还有哪些优势?
沸MySQL分布式集群数据是怎么存储的?
热MySQL索引为什么能让查询效率提高?
热oracle怎么样实现数据库跨机房同步?
新安卓开发前需要考虑哪些问题?
怎样系统全面的分析oracle的AWR报告?
IS(信息系统)没有数据库,系统的数据如何存储?
开发APP软件需要哪些编程语言和开发环境?
互联网、金融这两个领域上用于数据挖掘、数据分析的数据库是什么?
一个搜索框对应数据库多个字段,后台怎么对应?
什么是四层(L4 proxy)和七层负载均衡(L7 proxy)?
用count(*)做判断条件怎么弄的好一点?
为什么用navicat连接sqlserver后看不到master数据库?
MySQL的select语句怎么输出多行常量?