有没有办法为nhibernate会话/活动记录范围禁用Active Record验证?
我有一个场景,我们正在执行大量项目的删除 - 在某些情况下,客户的数据库中有数据不会通过验证(它是在引入新验证规则之前捕获的,或者是由于手册操纵数据库等。)
删除时,由于构建数据库的方式,会对现有实体进行一些验证检查,并且会因异常而失败 - 阻止删除这些实体。
对于删除方案,我们希望禁用与实体被删除的事务/会话/范围相关联的所有验证,这可能吗?
更新23/01/2011
实现了一个简单的验证活动记录基类,用于禁用验证:
public class DisabledValidationProvider : IValidationProvider
{
public bool IsValid()
{
return true;
}
public bool IsValid(RunWhen runWhen)
{
return true;
}
public string[] ValidationErrorMessages
{
get { return null; }
}
public IDictionary PropertiesValidationErrorMessages
{
get { return null; }
}
}
public class DisableValidationScope : IDisposable
{
public DisableValidationScope()
{
Local.Data["DisableValidationScope"] = true;
}
public static bool IsValidationDisabled
{
get { return Local.Data["DisableValidationScope"] != null; }
}
public void Dispose()
{
Local.Data["DisableValidationScope"] = null;
}
}
public abstract class ScopeAwareValidationBase : ActiveRecordHooksValidationBase
{
static readonly IValidationProvider DisabledProvider = new DisabledValidationProvider();
protected override IValidationProvider ActualValidator
{
get
{
if (DisableValidationScope.IsValidationDisabled)
{
return DisabledProvider;
}
return base.ActualValidator;
}
}
}
我的ActiveRecord模型继承自ScopeAwareValidationBase,然后我可以在我的事务代码周围使用一个using语句,然后处理。
using (new DisableValidationScope())
{
// do transactional thing...
}
答案 0 :(得分:2)
我会考虑覆盖ActualValidator
属性,你可以:
要禁用验证,您将返回一个虚拟IValidationProvider,它始终返回true给IsValid()等。