您可以使用 ObjectContext 对象提交或放弃一项由 Microsoft Transaction Server (MTS) 管理的事务它由 ASP 页包含的脚本初始化
ASP 包含 @TRANSACTION 指令时该页会在事务中运行直到事务成功或失败后才会终止
语法
thod
方法
SetComplete SetComplete 方法声明脚本不了解事务未完成的原因如果事务中的所有组件都调用 SetComplete事务将完成
SetAbort SetAbort 方法声明被脚本初始化的事务未完成无法更新源
事件
OnTransactionCommit
OnTransactionAbort
注释
ObjectContext 实现 MTS ObjectContext 对象的两种方法 SetAbort 方法完全终止事务这样MTS 不更新在第一阶段联系的源事务终止时将处理脚本的 OnTransactionAbort 事件
调用 SetComplete 方法并不一定意味着事务已完成只有脚本调用的所有事务组件都调用了 SetComplete事务才能完成在大多数实例中如果结束处理时未调用 SetAbort脚本通常被假定为完成的所以不一定要在脚本内调用 SetComplete
ObjectContext 展示了 SetAbort 和 SetComplete 以外的六种方法这些方法可用于脚本调用的组件但不能直接用于 ASP 脚本
示例
这里示范使用 SetAbort 和 SetCommit 的方法 文件获取处理销售请求所需的数据第二个文件——SalesVerifyasp 中的脚本使用两个对象——Inventory 和 Sales 处理销售如果 Inventory 返回了错误代码表示供销售的存货不足就会调用 SetAbort如果 Inventory 对象没有返回错误代码将会调用 SetComplete 处理销售请求
<!DOCTYPE HTML PUBLIC //IETF//DTD HTML//EN>
<HTML>
<HEAD>
<TITLE>Sales Order</TITLE>
</HEAD>
<BODY BGCOLOR=#FFFFFF><FONT FACE=ARIALHELVETICA>
<H>Sales Order Form </H>
<FORM METHOD=POST ACTION=SalesVerifyasp>
<P>Please enter the product code quantity and your account number
<INPUT TYPE=TEXT NAME=QuantityToBuy>
<INPUT TYPE=TEXT NAME=ProductCode>
<INPUT TYPE=TEXT NAME=AccountIn>
<P>
<INPUT TYPE=SUBMIT>
</FONT>
</BODY>
</HTML>
SalesVerifyasp 文件
<%@ Transaction = Required %>
<%
Set CurrentQOH = ServerCreateObject(MycompInventory)
Set CurrentSales = ServerCreateObject(MycompSales)
CheckQuantity = Request(QuantityToBuy)
CheckProduct = Request(ProductCode)
QuantityStatus = CurrentQOHCheckQOH(CheckQuantityCheckProduct)
If QuantityStatus = None
ObjectContextSetAbort
ResponseWrite Sorry there is not sufficient quantity on hand to process your sale
Else
ObjectContextSetComplete
Account = Request(AccountIn)
Saleupdate = CurrentSalesPostIt(AccountIn)
End If
%>