阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】 某超市销售系统的部分关系模式如下: 商品表:Commodity(Ccode,Cname,price,qty),其中属性含义分别为:商品编号、商品名称、价格、库存量。有

admin2020-04-30  4

问题 阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
    某超市销售系统的部分关系模式如下:
    商品表:Commodity(Ccode,Cname,price,qty),其中属性含义分别为:商品编号、商品名称、价格、库存量。有专门的事务保证库存量足够大,销售时无须检测。
    销售表:Sale(Sno,Ccode,amount,Stime),其中属性含义分别为:销售编号、商品编号、数量、时间。
    其销售业务规则如下:顾客在超市挑选好商品后,携带商品到结算处结算付款,结算处有多名结算员使用多台机器进行结算。结算员负责扫描顾客购买商品的条码和数量,由系统后台结算程序计算出顾客购买商品的总金额,修改商品表的商品库存量,并将销售信息写入销售表。
    请根据上述描述,回答以下问题。
    下面是用SQL实现的结算程序,请补全空缺处的代码。
    要求在保证销售信息不丢失的前提下,达到最大的系统并发度。
    CREATE PROCEDURE buy(IN:CommNo VARCHAR(20),IN:AmountBuy INT)
    BEGIN
    //输入合法性验证
    if(:AmountBuy<1)  return -1;
    SET TRANSACTION ISOLATION LEVEL  (a)________________;
    BEGIN TRANSACTION;
    //插入销售记录
    INSERT INTO Sale
    VALUES(getGUID(),:CommNo,:AmountBuy,  getcDATETIME());
    //函数getGUID():获取唯一值
    //函数getDATETIME():获取当前系统日期时间
    if error    //error是由DBMS提供的上一句SQL的执行状态
    BEGIN
    ROLLBACK ;  return一2;
    END
    //修改库存数量
    UPDATE Commodity
    SET qty=  (b)________________
    WHERE  Ccode=:CommNo ;
    if error
    BEGIN
    ROLLBACK;  return一3;
    END
    (c)________________
    END

选项

答案(a)read uncommited (b)qty一:AmountBuy (c)COMMIT;return0;

解析     本题目以存储过程的形式编程实现销售事务,对比第一问所示的事务增加了销售记录的写入。
    空缺(a)处是要完成事务隔离级别的设置。销售事务实现的是数据写入,要保证不产生丢失修改的不一致性,四个隔离级别中的最低级别read uncommited即可解决丢失修改问题,从提高并发性考虑,选此级别。
    空缺(b)处为库存量的修改,根据程序所给的变量使用规则(变量名前加冒号)和存储过程的形参定义及在上文.INSERT指令中的使用,可知此处应填写qty一:AmountBuy,即当前库存量减去销售数量。
    空缺(c)处为事务中所有操作执行完之后,事务正确结束的结点,应提交事务并反回执行状态。由程序中的错误状态返回值为负数值及默认规则,此处返回值宜设为0。
转载请注明原文地址:https://kaotiyun.com/show/PrUZ777K
0

相关试题推荐
最新回复(0)