当前位置:首页 → 计算机类 → 软件水平考试 → 中级数据库系统工程师->某超市销售系统部分关系模式如下:商品表:Commodity(
某超市销售系统部分关系模式如下:商品表: Commodity(Ccode, Cname, price,qty),其中属性含义分别为:商品编号、商品名称、价格、库存量,有专门事务保证库存量足够大,销售时无需检测。销售表: Sale(Sno,Ccode, amount, Stime),其中属性含义分别为:销售编号,商品编号、数量、时间。其销售业务规则如下:顾客在超市挑选好商品后,带商品到结算处结算付款,结算处有多名结算员使用多台机器进行结算。结算员负责扫顾客购买商品条码和数量,由系统后台结算程序计算出顾客购买商品总金额,修改商品表商品库存量,并将销售信息写入销售表。
【问题1】假设有两个顾客同时购买同一条码商品,结算事务修改该商品库存量(记为数据项 X),部分调度如图 5-1 所示。

如果购买前 X 初值为 10,则上述调度执行完成后,X 值是多少?属于哪一类不一致性?
【问题2】 引入独占锁指令 Xlock()和解锁指令 Unlock(),对【问题 1】中调度进行重写,要求满足两段锁协议,且事务 T1、T2 首条指令相对请求时间与【问题 1】中相同。
【问题 3】下面是用 SQL 实现结算程序,请补全空缺处代码。要求在保证销售信息不丢失前提下,达到最大系统并发度。CREATE PROCEDURE buy(IN: CommNo VARCHAR(20), IN: AmountBuy INT)BEGIN//输入合法性验证if(: AmountBuyimage.png1) return-1;SET TRANSACTION ISOLATIONLEVEL (a);BEGIN TRANSACTION;//插入销售记录INSERT INTO SaleVALUES(getGUID(),: CommNo, AmountBuy, getDATETIME());//函数 getGUID():获取唯一值//函数 getDATETIME():获取当前系统日期时间If error ∥error 是由 DBMS 提供上一句 SQL 执行状态BEGNROLLBACK; return-2;END//修改库存数量UPDATE CommoditySETqty= (b)WHERE Ccode=: CommNo;if errorBEGINROLBACK; return-3;END(c)END
【问题1】(1)第2人,并发操作出现了丢失更新问题,第2个更新覆盖了第1个更新,原因是破坏了事物隔离性。(2)会产生死锁,由于数据X同时被1和2加锁了S锁,再对方没有释放时候,都无法加成功X锁,导致1和2一直都处于等待状态(3)XLock(X) a=R(X) W(b,X)UNLock(X)
【问题2】
【问题3】(a)REPEATABLE READ(b)qty-:AmountBuy;(c)Commit;Return 0;END TRANSACTION









