如何处理以下问题?Equals和GetHashCode中的惰性加载的NHibernate属性
我们使用懒加载NHibernate特性,每当我们调用Equals()
或GetHashCode()
使用任何属性,将延迟加载,可能导致延迟加载操作的级联。急切加载可以用作替代,但我认为只有在特定情况下,而不是作为一般解决方案。
一个典型的情况是这样的:
实施GetHashCode
和
Equals(object)
public class AbstractSaveableObject {
[Id(0, Name = "Id", UnsavedValue = null)]
[Generator(1, Class = "native")]
public virtual long? Id { get; set; }
}
[Class(NameType = typeof(ClassA))]
public class ClassA : AbstractSavableObject {
[Bag(0, Inverse = true, Cascade = "none")]
[Key(1, Column = "ClassA")]
[OneToMany(2, ClassType = typeof(ClassB))]
public virtual ICollection<ClassB> ClassBs { get; set; }
}
[Class(NameType = typeof(ClassB))]
public class ClassB : AbstractSavableObject {
[ManyToOne(Column = "ClassA")]
public virtual ClassA ClassA { get; set; }
[ManyToOne]
public virtual ClassC ClassC { get; set; }
[ManyToOne]
public virtual ClassD ClassD { get; set; }
public virtual bool Equals(ClassB other)
{
if (ReferenceEquals(null, other))
{
return false;
}
if (ReferenceEquals(this, other))
{
return true;
}
return Equals(other.ClassC, ClassC) && Equals(other.ClassD, ClassD);
}
}
已为简洁起见省略。
有什么策略可以用来解决这个问题?
您的实体上没有任何主键吗? – asgerhallas 2011-02-15 12:05:35
是的,我做了,我省略了它们,实际上所有持久化类都来自包含代理主键的抽象基类。 – 2011-02-15 12:24:29