Wie kann das folgende Problem gelöst werden?
Wir verwenden "lazy loaded". NHibernate Eigenschaften und wann immer wir die Equals()
o GetHashCode()
alle verwendeten Eigenschaften werden "lazy-loaded", was zu einer Kaskade von "lazy-loading"-Vorgängen führen kann. Eager-Loading könnte als Alternative verwendet werden, aber ich denke, nur in bestimmten Fällen und nicht als allgemeine Lösung.
Ein typisches Szenario würde folgendermaßen aussehen:
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);
}
}
Durchführung von GetHashCode
et Equals(object)
wurden der Kürze halber weggelassen.
Welche Strategien können zur Lösung dieses Problems eingesetzt werden?