这个是为了解决:当多个根对象依次提交数据,通过“数据门户”在应用服务器上进行数据库UID操作时,如何保证在同一个事务当中。
下面是CommandBase中的代码,BusinessListBase中的代码类似。
using System;
using System.Data.Common;
using Phenix.Core;
namespace Phenix
{
/// <summary>
/// 命令基类
/// 支持同一UserPrincipal的事务控制,请使用Phenix.Core.TransactionalAttribute标签
/// 也就是说, 可通过它,将多步数据库操作放在一个事务当中,而与sessin调用方式无关
/// </summary>
[Serializable()]
public abstract class CommandBase : Csla.CommandBase
{
#region 过程
/// <summary>
/// 执行命令
/// </summary>
/// <param name="command">命令对象</param>
public static void Execute(CommandBase command)
{
Csla.DataPortal.Update(command);
}
#region Data Access
protected override void DataPortal_Execute()
{
DefaultDatabase.Execute(this, Csla.ApplicationContext.User.Identity.Name, DoExecute);
}
/// <summary>
/// 执行命令
/// </summary>
/// <param name="transaction">数据库事务</param>
protected abstract void DoExecute(DbTransaction transaction);
#endregion
#endregion
}
}