博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用锁实现SQLSERVER中简单并发控制(转)
阅读量:5960 次
发布时间:2019-06-19

本文共 979 字,大约阅读时间需要 3 分钟。

研究Oracle的同学都知道,Oracle的select语句中可以使用for update或者for update nowait来控制并发,这一功能可以使开发人员轻易的将锁定控制在会话级+行级,可以说是高度并发的利器。

 

而在SQLSERVER中却没有如此功能,但很多开发人员,尤其是WEB开发人员,大都遇到过类似情况,比如电商中的秒杀,程序需要先读一下表中的那条记录(比如待售商品),如果存在,那么,马上去购买,即update操作,但要防止很多人同时读到了记录,否则将会出现意想不到的问题。所以,如果数据库是oracle,相信实现起来比较容易一些,但如果是SQLSERVER的话,就要困难一些,那么能否让SQLSERVER也实现上述功能呢,如果表中的数据量不是很大,我建议大家这样操作,人工使用表级锁定,方法如下:

--1.为了稳妥,先要确认一下事务隔离级别:

 

--2.使用显式事务,并且使用手工指定表级锁定。

begin transaction

select * from ls1 with (tablockx) where f_account_id=37
....
....

update ls1 set .....

commit;

 

 

--这样就可以了,之所以要使用手工指定表级锁定,因为在所有表锁定提示关键字中,只有tablockx是排它的,共享锁和更新锁是没有办法阻塞住其他用户对同一记录的查询的。因此退而求其次,只得使用表级排它锁了。如果表中的记录数量很多,这个方法显然不可行的,请大家使用时一定注意。

--当然还有另一种方法,只是将排它锁限定到行级,但却要求所有的查询语句全部手工指定锁定级别,如下所示:

--所有查询语句均使用表提示with(rowlock,xlock)

begin transaction 

select * from ls1 with (rowlock,xlock) where f_account_id=37

 

update ls1 set .....

commit;

--注意上述表提示语句不能阻止共享锁,但可以阻止其他排它锁,只要所有的查询语句,在查询时全部带上with (rowlock,xlock)即可。

 

转自【新浪博客】【

 

转载于:https://www.cnblogs.com/MLGB/p/4164986.html

你可能感兴趣的文章
Python中的Numpy入门教程
查看>>
PHP学习1——快速入门
查看>>
面试发散思维
查看>>
java日志commons-logging/log4j/slf4j/logBack需要知道的几件事
查看>>
TypeScript 2019 路线图:更效率,更易用!
查看>>
Springboot从HellWorld开始
查看>>
Apache uimaFIT 3.0.0 发布,Java 的 UIMA 注解类
查看>>
用js来实现那些数据结构15(图01)
查看>>
web前端学习:React是什么,为什么要使用它?
查看>>
Cockpit 188 发布,交互式服务器管理界面
查看>>
常见排序算法及对应的时间复杂度和空间复杂度
查看>>
业界 | 在德州叫一辆自动驾驶车,Drive.ai安排了7辆无人车展开真实试验
查看>>
实时数据平台设计:解决从OLTP到OLAP实时流转缺失
查看>>
三家公司在SD-WAN方面的新动作
查看>>
C#在PDF中如何以不同颜色高亮文本
查看>>
在同一页面显示多个JavaScript统计图表
查看>>
Mac电脑Tomcat下载及安装(详细)MAC在Eclipse里配置tomcat
查看>>
多线程之-----------定时器
查看>>
C#语法——反射,架构师的入门基础。
查看>>
Beego Models 之 一
查看>>