王朝网络
分享
 
 
 

事务保存点在一个订购系统中的使用情况

王朝other·作者佚名  2008-07-22
宽屏版  字体: |||超大  

保存点提供了一种机制,用于回滚部分事务。可以使用 SAVE TRANSACTION savepoint_name 语句创建一个保存点,然后再执行 ROLLBACK TRANSACTION savepoint_name 语句回滚到该保存点,从而无须回滚到事务的开始。

在不可能发生错误的情况下,保存点很有用。在很少出现错误的情况下使用保存点回滚部分事务,比让每个事务在更新之前测试更新的有效性更为有效。更新和回滚操作代价很大,因此只有在遇到错误的可能性很小,而且预先检查更新的有效性的代价相对很高的情况下,使用保存点才会非常有效。

下面的示例显示保存点在一个订购系统中的使用情况。该系统中存货不足的可能性很小,因为该公司具备有效的供应商和再订购点。通常应用程序在尝试更新订购记录时,会先验证手边是否有足够的存货。该示例假定由于某种原因(如连接到一个低速的调制解调器或广域网上),先验证可用存货的数量代价相对较大。可将应用程序编写为只进行更新,而且如果收到错误信息,表明库存不足时,将回滚该更新。在这种情况下,在插入之后快速检查 @@ERROR 比在更新之前验证库存数量速度要快得多。

InvCtrl 表有一个 CHECK 约束,如果 QtyInStk 列低于 0,就会触发 547 号错误。OrderStock 过程创建一个保存点。如果出现 547 错误,它将回滚到该保存点,并将当前手边有的项目数返回给调用进程。然后调用进程可以决定是否需要针对手边现有的数量重新下订单。如果 OrderStock 返回一个 0,则调用进程知道当前有足够的存货,可以满足订购需要。

SET NOCOUNT OFF

GO

USE pubs

GO

CREATE TABLE InvCtrl

(WhrhousID int,

PartNmbr int,

QtyInStk int,

ReordrPt int,

CONSTRAINT InvPK PRIMARY KEY

(WhrhousID, PartNmbr),

CONSTRAINT QtyStkCheck CHECK (QtyInStk > 0) )

GO

CREATE PROCEDURE OrderStock @WhrhousID int, @PartNmbr int,

@OrderQty int

AS

BEGIN TRANSACTION StkStock

DECLARE @ErrorVar int

SAVE TRANSACTION StkOrdTrn

UPDATE InvCtrl SET QtyInStk = QtyInStk - @OrderQty

WHERE WhrhousID = 1

AND PartNmbr = 1

SELECT @ErrorVar = @@error

IF (@ErrorVar = 547)

BEGIN

ROLLBACK TRANSACTION StkOrdTrn

RETURN (SELECT QtyInStk

FROM InvCtrl

WHERE WhrhousID = @WhrhousID

AND PartNmbr = @PartNmbr)

COMMIT TRANSACTION

END

ELSE

COMMIT TRANSACTION

RETURN 0

GO

insert InvCtrl(WhrhousID,PartNmbr,QtyInStk)values(1,1,2)

update InvCtrl set QtyInStk=2 where WhrhousID=1

exec OrderStock 1,1,1

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有