1. 首页
  2. 数据库系统工程师
  3. 2018年上半年数据库系统工程师考试下午真题【应用技术】
  4. 真题详解

2018年上半年数据库系统工程师考试下午真题【应用技术】(第5题)

试题【5】(15分)

  阅读下列说明和图,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
  某超市销售系统的部分关系模式如下
  商品表:Commodity(Ccode,Cname,price,qty),其中属性含义分别为:商品编号、商品名称、价格、库存量,有专门的事务保证库存量足够大,销售时无需检测。
  销售表:Sale(Sno,Ccode,amount,Stime),其中属性含义分别为:销售编号,商品编号、数量、时间。
  其销售业务规则如下:顾客在超市挑选好商品后,带商品到结算处结算付款,结算处有多名结算员使用多台机器进行结算。结算员负责扫顾客购买商品的条码和数量,由系统后台结算程序计算出顾客购买商品的总金额,修改商品表的商品库存量,并将销售信息写入销售表。
  请根据上述描述,回答以下问题。

问题1(3.0分)

  假设有两个顾客同时购买同一条码的商品,结算事务修改该商品的库存量(记为数据项X)部分的调度如图5-1所示。

  如果购买前X的初值为10,则上述调度执行完成后,X的值是多少?属于哪一类不一致性?
暂无

问题2(6.0分)

  引入独占锁指令Clock()和解锁指令Unlock(),对【问题1】中的调度进行重写,要满足两段锁协议,且事务T1、T2首条指令的相关请求时间与【问题1】中的相同。
暂无

问题3(6.0分)

  CREATE PROCEDURE buy(IN:CommNo VARCHAR(20),IN:AmountBuy INT)
  BEGIN
  If(:AmountBuy<1) return-1;
  SET TRANSACTION ISOL ATION LEVEL (a)
  BEGIN TRANSACTION;      //插入销售记录
  INSERT INTO Sale
  VALUES(getGUID(),:CommNo,AmountBuy,getDATETIME());
  //函数getGUID():获取唯一值
  //函数getDATETIME():获取当前系统日期时间
  if error       //error是由DBMS提供的上一句SQL的执行状态
  BEGIN
  ROOLLBACK;    return-2;
  END
  UPDATE Commodity
  SET qty=(b)
  WHERE Ccode=:CommNo;
  if error
  BEGIN
  ROLLBACK;    return-3;
  END
  (c)
  END
暂无
广告位
试题标签
难度评价
  • 容易 0%
  • 中等 0%
  • 偏难 0%