20150716 Created By BaoXinjian
一、摘要
TransactionUnitHelper用以创建一个被标记的Transaction,个人感觉类似PLSQL SavePoint用以Commit和Rollback特定交易的作用
主要用法
1. 交易开始时TransactionUnitHelper.startTransactionUnit,创建交易标志
2. 交易过程中TransactionUnitHelper.isTransactionUnitInProgress,判断交易是否正在处理中
3. 交易完成后TransactionUnitHelper.endTransactionUnit,结束该标志交易
二、锁定统计信息
1. CO中处理交易过程
public void processRequest(OAPageContext pageContext, OAWebBean webBean)
{
super.processRequest(pageContext, webBean);
// 判断页面不是导航Back
if (!pageContext.isBackNavigationFired(false))
{
// 创建交易标志
TransactionUnitHelper.startTransactionUnit(pageContext, "purProgUpdateTxn");
if (!pageContext.isFormSubmission())
{
OAApplicationModule am = pageContext.getApplicationModule(webBean);
am.invokeMethod("createEmployee", null);
}
}
else
{
// 判断交易是否正在处理
if (!TransactionUnitHelper.isTransactionUnitInProgress(pageContext,"purProgUpdateTxn",true))
{ // 提示交易正在处理中
OADialogPage dialogPage = new OADialogPage(NAVIGATION_ERROR);
pageContext.redirectToDialogPage(dialogPage);
}
}
}
2. 回滚和提交
// 对交易进行回滚
if (TransactionUnitHelper.isTransactionUnitInProgress(pageContext,"purProgUpdateTxn",false)) {
am.rollbackPurProgram();
TransactionUnitHelper.endTransactionUnit(pageContext,"purProgUpdateTxn");
}
// 对交易进行提交
else {
am.commitPurProgram();
TransactionUnitHelper.endTransactionUnit(pageContext,"purProgUpdateTxn");
}
Thanks and Regards
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建