假设我有两个类:
public class A
{
public virtual int Id { get; set; }
public virtual Object1 Obj { get; set; }
}
public class B : A
{
public new virtual Object2 Obj { get; set; }
}
我使用 Fluent NHibernate 并为这两个类创建了两个不同的映射。但是,当我尝试在我的存储库中查询 A 类时,FNH 找到了 B 类和 A 类,这是有道理的,因为它们都是 A。
示例(此条件将同时查询 A 和 B):
public List<T> GetByName(string name)
{
return Session.CreateCriteriaOf<A>.Add(Restrictions...);
}
写CreateCriteriaOf<A>
时, 我只想查询 A - 而不是 B。我该如何解决我的问题?
最佳答案
我认为你最好创建一个继承树,其中 A 和 B 都派生自一个公共(public)(抽象)基类型。然后 NHibernate 可以通过 discriminator column 来区分。 .
当然,你的数据模型应该适应这一点,所以我希望你的模型没有以任何方式规定。
关于c# - Fluent NHibernate - 查询派生类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7633225/