开发者社区> mcy247> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

知方可补不足~UPDLOCK更新锁的使用

简介:
+关注继续查看

对于高并发的场合下,使用UPDLOCK可以有效的控制并发更新的问题,即当一个线程在进行with(UPDLOCK)并进行update时,另一个线程将被阻塞,它会等第一个线程更新结束后,才可以进行它里面的操作,使用UPDLOCK有效的避免了并发更新而产生的数据错误的问题,如累加操作,第二个线程需要等第一个线程累加结束后,才能进行下一步的累加动作,这是我们可以接受的。

测试代码如下

BEGIN TRAN
SELECT  *
FROM    WebManageUsers WITH ( UPDLOCK )
WHERE   LoginName = 'zzl'
WAITFOR DELAY '00:00:10'
UPDATE  WebManageUsers
SET     RealName = 'zzlreal11'
WHERE   LoginName = 'zzl'
COMMIT TRAN

代码运行后,再打开一个SQL客户端,进行下面代码的修改

BEGIN TRAN
SELECT  *
FROM    WebManageUsers WITH ( UPDLOCK )
WHERE   LoginName = 'zzl'
WAITFOR DELAY '00:00:10'
UPDATE  WebManageUsers
SET     RealName = 'zzlreal22'
WHERE   LoginName = 'zzl'
COMMIT TRAN

 本文转自博客园张占岭(仓储大叔)的博客,原文链接:知方可补不足~UPDLOCK更新锁的使用,如需转载请自行联系原博主。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
彻底理解ReentrantLock可重入锁的使用
java除了使用关键字synchronized外,还可以使用ReentrantLock实现独占锁的功能。而且ReentrantLock相比synchronized而言功能更加丰富,使用起来更为灵活,也更适合复杂的并发场景。这篇文章主要是从使用的角度来分析一下ReentrantLock。
41 0
RocketMQ第九章:手把手教老婆代码实现-事务消息生产者和事务消息消费者 及深入源码探索事务的消息回查
RocketMQ第九章:手把手教老婆代码实现-事务消息生产者和事务消息消费者 及深入源码探索事务的消息回查
96 0
ECS 7天实践训练营——快速搭建Docker环境
本文利用阿里ECS资源快速搭建Docker环境,并对结果进行记录
132 0
在WinSock上使用IOCP
因此你应该使用只被Winsock2中IOCP允许的函数来使用IOCP。在ReadFile和WriteFile中会发生的额外的参数重整以及模式转换只会发生在一种情况下,那就是如果句柄的提供者并没有将自己的WSAPROTOCOL_INFO结构中的DwServiceFlags1设置为XP1_IFS_HANDLES。
1252 0
进销存系统(1):开源ECP编译安装
本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/49643521 未经博主允许不得转载。 博主地址是:http://blog.csdn.net/freewebsys 1,关于ECP ECP 是基于jfinal、avalon、bootstrap、jqGrid、snaker工作流开发的客户关系及进销存财
2421 0
Bootstrap系列 -- 1. 如何使用Bootstrap
一. Bootstrap 简介   Bootstrap 是一个前端框架,使用Bootstrap可以做出很多漂亮的页面,中文官网:http://www.bootcss.com/    二. Bootstrap核心    Bootstrap核心是Bootstrap.
1023 0
+关注
mcy247
做自己的太阳 无需凭借谁的光
1070
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载