当前位置: 首页 > news >正文

pb并发控制

   

并发控制(一)

 

   并发能力是指多用户在同一时间对相同数据同时访问的能力。一般的关系型数据库都具 有并发控制的能力,但是这种并发功能也会对数据的一致性带来危险。试想若有两个用 户都试图访问某个银行用户的记录并同时要求修改该用户的存款余额时,情况将会怎样 呢?我们可以对PowerBuilder中的DataWindow进行设置来进行并发控制。所谓并发控制 就是指在用户数据修改的过程中保证该数据不被覆盖或改变的方式,在下面的例子中我 们将看到如何设置DataWindow来控制开发访问。为了说明问题,我们举这样一个简单的 银行系统中的例子,某用户的存款状况如右:

我们假设事情的经过是这样的:公司的某员工在银行前台取款2,000元,银行出纳查询用 户的存款信息显示银行存款余额20,000元;正在这时,另一银行帐户转帐支票支付该帐户 5,000元,机器查询也得到当前用户存款20,000元,这时银行的出纳员看到用户存款超过 了取款额,就支付了客户2,000元并将用户存款改为18,000元,然后银行的另一名操作员 根据支票,将汇入的5,000元加上,把用户的余额改为25,000元,那么数据库管理系统是否 可以接受这些修改呢?

在DataWindows的设计中,我们选择菜单Rows|Update…,会出现 SpecifyUpdateCharacteristics的设置窗口,在这个窗口中我们设置Update语句中Where 子句的生成,以此来进行开发控制。在这里有三个选项,我们分别看一看在本例中这三个 选项的结果:

(1) KeyColumns:生成的Where子句中只比较表中的主键列的值与最初查询时是否相同来确定要修改的记录。在上述的例子中,转帐支票的操作将覆盖出纳员作出的修改,这样银行损失两千元。
(2) KeyandUpdateableColumns:生成的Where子句比较表中主键列和可修改列的值与最初查询时否是相

http://www.lryc.cn/news/13899.html

相关文章:

  • 登录拦截器
  • STM32 - HAL库UART串口
  • Vue3 的状态管理库(Pinia)
  • 信息系统项目管理师知识点汇总(2023最新)
  • 标题标题标题
  • OKR学习总结二
  • MAC中docker搭建fastdfs
  • JavaScript 变量
  • 【前端验证】环境仿真中对于寄存器配置的随机策略讨论
  • Servlet如何读取Web资源文件?【操作演示】
  • [ vulhub漏洞复现篇 ] Drupal 远程代码执行漏洞(CVE-2019-6339)
  • flex-shrink和felx-grow
  • 将HTTP接口配置成HTTPS
  • YOLOV5报错解决办法
  • java final关键字 详解
  • Vbs_To_Exe制作简易exe程序
  • AI制药 - TMScore(US-align)、RMSD、Sequence 源码
  • 关于个人的经历
  • 设计在单链表中删除值相同的多余结点的算法(包括指针的引用的知识点)
  • 100份简历才找一个合适的,2023,软件测试岗位饱和了吗?
  • (三十七)vue 项目中常用的2个Ajax库
  • Python打包调试问题解决
  • 计算机SCI期刊自引率一般是多少? - 易智编译EaseEditing
  • 力扣(LeetCode)417. 太平洋大西洋水流问题(2023.02.19)
  • Python解题 - CSDN周赛第30期 - 天然气订单
  • 移动WEB开发一、基础知识
  • 07 二叉树
  • 3|物联网控制|计算机控制-刘川来胡乃平版|第4章:过程通道与人机接口-4.1数字量输入输出通道接口|课堂笔记|ppt
  • 从 ClickHouse 到 Apache Doris,腾讯音乐内容库数据平台架构演进实践
  • linux线程的基本知识