SqlServer查询记录的时候提供多种锁定方式,其中UPDLOCK 的优点是允许您读取数据(不阻塞其它事务)并在以后更新数据,同时确保自从上次读取数据后数据没有被更改。当我们用UPDLOCK来读取记录时可以对取到的记录加上更新锁,从而加上锁的记录在其它的线程中是不能更改的只能等本线程的事务结束后才能更改。
有时候我需要控制某条记录在我读取后就不许再进行更新,那么我就可以将所有要处理当前记录的查询都加上更新锁,以防止查询后被其它事务修改.将事务的影响降低到最小。假如不这样做,将整个表锁定,这种做法将严重影响了性能。
看下面的查询:
  1. begin tran
  2. select * from address WITH (UPDLOCK) where [Name]='Z'
  3. waitfor delay '00:00:10'
  4. update address set [Name]='X' where [Name]='Z'
  5. commit tran
这个示例中,在读取记录后,等待10秒来模拟耗时的操作,之后再更新这条记录。
上面这个例子可能比较抽象,让我们来举一个实际的例子。
假设有一个投资产品表,当我们查询到该产品记录后,要进行一系列的判断,最后对该记录进行更新。该记录的状态会影响到下一个人查询到此记录的处理。下面我们来看看用SOD框架的OQL怎么处理。
  1. decimal sumAmount = model.Amount + model.GvMoney;
  2. DateTime currentTime = DateTime.Now;
  3. AdoHelper db = AdoHelper.CreateHelper("defaultDB");
  4.  
  5. db.BeginTransaction();
  6. try
  7. {
  8. //查询相关产品余额剩多少够不够买的
  9. var pro = EntityQuery<Pro_Products>.QueryObject(
  10. OQL.From<Pro_Products>()
  11. .With(OQL.SqlServerLock.UPDLOCK)
  12. .Select()
  13. .Where<Pro_Products>((cmp, p) => cmp.Property(p.proNumber) == model.ProNumber)
  14. .END, db);
  15. if (pro == null)
  16. {
  17. db.Rollback();
  18. return new OrderingModel { Msg = "剩余可投金额不足" };
  19. }
  20. //2015 08 06 打开原有注释,限制投资金额
  21. if (sumAmount < || sumAmount % != )
  22. {
  23. db.Rollback();
  24. return new OrderingModel { Msg = "投标金额不正确" };
  25. }
  26.  
  27. //线下标下单时,不可使用现金券
  28. if (SetObject.IsOffline(pro.ProType))
  29. {
  30. sumAmount = model.Amount;
  31. }
  32. if (pro.Surplus < sumAmount)
  33. {
  34. db.Rollback();
  35. return new OrderingModel { Msg = "剩余可投金额不足" };
  36. }
  37. if (currentTime < pro.starttime)
  38. {
  39. db.Rollback();
  40. return new OrderingModel { Msg = "还未开始" };
  41. }
  42. var giveAward = ;
  43. if (pro.Surplus == sumAmount)
  44. {
  45. if (sumAmount >= && sumAmount < )
  46. {
  47. giveAward = ;
  48. }
  49. if (sumAmount >= )
  50. {
  51. giveAward = ;
  52. }
  53. }
  54. //扣除产品可用金额
  55. pro.Surplus -= sumAmount;
  56. if (pro.Surplus == )//最后一笔 更新满标状态
  57. {
  58. pro.Prostatus = "";
  59. //pro.Paymentime = currentTime.AddDays(1);
  60. pro.Paymentime = currentTime;
  61. //
  62. pro.ProOrder = ;
  63. }
  64.  
  65. EntityQuery<Pro_Products>.Instance.Update(pro, db);
  66.  
  67. //其它复杂的处理逻辑,更新其它表的操作,略...
  68.  
  69. db.Commit();

上面的操作,首先在AdoHelper对象上开启事务,然后查询投资产品实体的时候在With方法上加上 OQL.SqlServerLock.UPDLOCK 更新锁,接着进行复制的业务处理,然后更新此实体记录,之后还有复杂的其它业务操作,最后提交事务。

我们看到,OQL的这种更新锁操作,跟直接写SQL语句操作很类似,OQL执行的时候也是这样输出SQL语句的,这样确保数据记录在并发的时候,安全的更新。

注意:OQL更新锁目前只支持SqlServer数据库。

在OQL上使用UPDLOCK锁定查询结果,安全的更新实体数据的更多相关文章

  1. hive(在大数据集合上的类SQL查询和表)学习

    1.jdbc:mysql://localhost:3306/hive?createDatabaseIfNotExist=true&characterEncoding=UTF-8&use ...

  2. DBA查询命令积累——不断更新

    原文:DBA查询命令积累--不断更新 一.服务器配置: 1.兼容级别:兼容级别只影响指定数据库中的行为,而不会影响整个服务器上的行为. 1.1.查看数据库兼容级别及更改兼容级别: SELECT com ...

  3. 使用TSQL查询和更新 JSON 数据

    JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...

  4. 结合bootstrap fileinput插件和Bootstrap-table表格插件,实现文件上传、预览、提交的导入Excel数据操作流程

    1.bootstrap-fileinpu的简单介绍 在前面的随笔,我介绍了Bootstrap-table表格插件的具体项目应用过程,本篇随笔介绍另外一个Bootstrap FieInput插件的使用, ...

  5. 使用DB查询分析器实现异构数据源中数据表的相互访问

    1  引言   硕士程序员马根峰(CSDN专访马根峰:海量数据处理与分析大师的中国本土程序员)推出的个人作品----万能数据库查询分析器,中文版本DB 查询分析器.英文版本<DB Query A ...

  6. mybatis查询语句的背后之封装数据

    转载请注明出处... 一.前言 继上一篇mybatis查询语句的背后,这一篇主要围绕着mybatis查询的后期操作,即跟数据库交互的时候.由于本人也是一边学习源码一边记录,内容难免有错误或不足之处,还 ...

  7. 数据在千万级别上进行全文检索有哪些技术?强大的大数据全文索引解决方案-ClouderaSearch

    数据在千万级别上进行全文检索有哪些技术?强大的大数据全文索引解决方案-ClouderaSearch1.lucene (solr, elasticsearch 都是基于它) 2.sphinx3.elas ...

  8. EF Core 中多次从数据库查询实体数据,DbContext跟踪实体的情况

    使用EF Core时,如果多次从数据库中查询一个表的同一行数据,DbContext中跟踪(track)的实体到底有几个呢?我们下面就分情况讨论下. 数据库 首先我们的数据库中有一个Person表,其建 ...

  9. elasticsearch查询篇索引映射文档数据准备

    elasticsearch查询篇索引映射文档数据准备 我们后面要讲elasticsearch查询,先来准备下索引,映射以及文档: 我们先用Head插件建立索引film,然后建立映射 POST http ...

随机推荐

  1. ASP.NET WebApi OWIN 实现 OAuth 2.0(自定义获取 Token)

    相关文章:ASP.NET WebApi OWIN 实现 OAuth 2.0 之前的项目实现,Token 放在请求头的 Headers 里面,类似于这样: Accept: application/jso ...

  2. linux 完全关闭tomcat

    由于直接调用tomcat的 shutdown.sh 有时无法完全关闭掉tomcat,使用 ps -ef | grep tomcat 查找发现tomcat依然还存在,并未完全关掉.在 catalina. ...

  3. ansible基础-理解篇

    1. 介绍 要说现在的部署工具,ansible可以说家喻户晓了. ansible是一个开源软件,用于软件供应.配置管理.应用部署.ansible可以通过SSH.remote PowerShell.其他 ...

  4. [Swift]LeetCode65. 有效数字 | Valid Number

    Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...

  5. Xapian的内存索引-添加文档

    本文主要记录Xapian的内存索引在添加文档过程中,做了哪些事情. 内容主要为函数执行过程中的流水线. demo代码: Xapian::WritableDatabase db = Xapian::In ...

  6. 【Spark篇】---Spark解决数据倾斜问题

    一.前述 数据倾斜问题是大数据中的头号问题,所以解决数据清洗尤为重要,本文只针对几个常见的应用场景做些分析 . 二.具体方法  1.使用Hive ETL预处理数据 方案适用场景: 如果导致数据倾斜的是 ...

  7. AttributeError: module 'pip' has no attribute 'main'

    Pycharm在运行pip安装模块是报错如下: 解决方法: 找到安装路径下的packaging_tool.py文件修改如下: 我的路径为D:\Program Files\JetBrains\PyCha ...

  8. IdentityServer4之Implicit(隐式许可)

    IdentityServer4之Implicit(隐式许可) 参考 官方文档:3_interactive_login .7_javascript_client 概念:隐式许可 认证服务端配置 认证服务 ...

  9. Python爬虫入门教程 12-100 半次元COS图爬取

    半次元COS图爬取-写在前面 今天在浏览网站的时候,忽然一个莫名的链接指引着我跳转到了半次元网站 https://bcy.net/ 打开之后,发现也没有什么有意思的内容,职业的敏感让我瞬间联想到了 c ...

  10. 从零开始学习PYTHON3讲义(三)写第一个程序

    <从零开始PYTHON3>第三讲 本页面使用了公式插件,因博客主机过滤无法显示的表示抱歉,并建议至个人主页查看原文. ​ 我见过很多初学者,提到编程都有一种恐惧感,起源是感觉编程太难了.其 ...