数据库事物单个逻辑单元工作执行的一系列操作,就是一些sql语句,也可以是多条,一个update操作就是一个事物。
事物具有四种特性
1.原子性
事物必须是原子工作单元,要么都执行成功(也就是说所有的sql语句都执行成功),要么都不执行(所有的sql语句都不执行)。
2. 一致性
事务在完成时,必须使所有的数据都保持一致状态。
3.隔离性
允许多个用户对数据进行并发访问,而不破环数据的完整行和正确性,同时,并发事物的修改必须与其他并发事物隔离,一般是通过加锁实现。
4.持久性
事物完成后,数据必须永久的保存到数据库中。
事物并发访问如果不设置事物的隔离级别,就会带来如下问题
1.脏读 读取了其他事物未提交的数据,一个事物修改了某条数据还未提交,一个事物读取了这条数据,而修改的事物由于某种原因失败会滚了,这个时候读取事物就读到了脏数据。
2.不可重复读
一个事物两次读取某条数据,但读取的结果不一样,在第二次读取的时候其他实物修改了这条数据。
3.幻读
一个事物两次读取,读取到了其他事物插入到数据中的数据。
针对以上情况,数据库提供了四种事物的隔离级别来解决事物并发带来的问题。
1.读未提交(read uncommited)
写事物会阻塞写事物,但不会阻塞读取事物,因此不能解决读取脏数据,读取事物不会阻塞其他事物,这中隔离级别不能解决上面任何问题。
2 读已经提交(read commited)
写事物会阻塞写事物和读取事物,因此可以避免读取脏数据,但读取事物不会阻塞写事物,不能解决可重复度去的问题。
3 可重复读(Repeatable read)
读事物会阻塞写事物和读事物,因此可以重复读,但其他事物可以进行插入操作,不能解决幻读的问题。
4 序列化(Serializable)
事物必须一个一个的执行 ,可以解决上面的问题,但事物基本没有并发性。
事物的并发控制
当多个人并发修改同一条数据时,必须实现一个控制系统,使一个人的修改不会对其他人的修改造成负面影响。
乐观锁和悲观锁控制并发
1.乐观锁
乐观的认为其他用户企图访问和更改你正在访问的对象的概率很低,即使有,大不了从来一次,对在做一次的开销不是很大的情况下,如果开销很大则必须使用悲观锁.乐观锁的实现需要在程序中控制,可以通过加一个数据版本号来控制比如两个事物都读取了同一条记录要进行更新
select * from person
select * from person
update person set name='xiaoming',version=version+1 where id='1'
and version=0;
这个更新语句会执行失败,因为找不到版本好为0的数据,第一个事物已经更新了
update person set name='xiaoming',version=version+1 where id='1'
and version=0;
如果实物的隔离级别设置为读已提交,使用乐观锁并能解决可重复度,系统要允许不可重复读取。
悲观锁
很悲观的认为其他用户访问和更改你正在访问或修改的对象的概率和高,悲观锁的实现是通过加锁来实现的,当要更改数据前就加锁,别的事物不能操作,sql语句如下
select * from person for update
update person set name='ff' where id='1'
直到上面事物提交,才能释放锁,其他事物才能操作。悲观锁的并发性会降低。因此大多数情况下,使用乐观锁来实现并发修改。
分享到:
相关推荐
[数据库事务与锁]详解七 深入理解乐观锁与悲观锁
介绍数据库事务的定义和事务带来的问题,详细讲解乐观锁与悲观锁的区别
共享锁,更新锁,乐观锁,悲观锁 和 数据库中锁的使用
悲观锁,正如其名,它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部 系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于...悲观锁的实现,往往依靠数据库提供的锁机制(通常是X锁)
NULL 博文链接:https://cdxs2.iteye.com/blog/1938245
数据库的锁,就是在表中添加一个字段,一般为Vwesion字段。
封锁的类型以及粒度,两段锁协议,隐式和显式锁定 封锁类型有两种:读写锁和意向锁 读写锁分类读锁(s锁)和写锁(x锁)。...乐观锁和悲观锁都是为了事务的并发控制。 乐观锁 悲观锁 目的 事务
主要介绍了SpringBoot整合MyBatis实现乐观锁和悲观锁的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Java 中的悲观锁和乐观锁的实现 纯开发技巧。
当前的PPT总共56页,从锁的介绍,到java锁(lock、synchronor、aqs)到分布式锁 redis、zk、数据库的悲观锁和乐观锁都有涉及,算是比较完整的一个PPT,适合涉及到锁相关的专题讲座,以及自学的PPT,后面有机会会开...
在关系型数据库中,悲观锁与乐观锁是解决资源并发场景的解决方案,接下来将详细讲解:magnifying_glass_tilted_right:一下这两个并发解决方案的实际使用及优缺点。 首先定义一下数据库,做一个最简单的库存表,如下...
乐观锁和悲观锁式并发控制主要采用的技术手段 悲观锁 在关系数据库管理系统中,悲观并发控制(悲观锁,PCC)是一种并发控制的方法。它可以阻止一个事务以影响其他用户的方式来修改数据。如果一个事务执行的操作的每...
所谓悲观锁,总是假设最坏的情况,每次去拿数据的时候都会认为别人会修改数据,造成幻读,不可重复读,脏读等情况发生。所谓乐观锁,重视假设最好的情况,每次去拿数据都认为别人不会修改,所以不会上锁,但是会在...
NULL 博文链接:https://12345678.iteye.com/blog/721836
数据库中事物与锁的课件,希望对大家有帮助。。
本文实例讲述了mysql 悲观锁与...悲观锁的实现,通常依靠数据库提供的锁机制实现,比如mysql的排他锁,select …. for update来实现悲观锁。 例子:商品秒杀过程中,库存数量的减少,避免出现超卖的情况。 CREATE TAB
在实际的多用户并发访问的生产环境里边,我们经常要尽可能的保持数据的一致性。...解决这样的办法,SQL SERVER提出了乐观锁定和悲观锁定的概念,本文以一个实例来说明如何使用乐观锁定和悲观锁定来解决这样的问题。
锁的定义: 数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则。 表级锁:开销小,加锁快;...一、悲观锁 顾名思义,就是对于数