我有以下定义的实体:
public class Foo : Entity<Foo.FooId>
{
public class FooId
{
public virtual String Bar { get; protected internal set; }
public virtual Int32 Buzz { get; protected internal set; }
}
// ...
}
这是基类:
public abstract class Entity<T> : IEquatable<Entity<T>>
{
public virtual T Id { get; protected internal set; }
// ...
}
我要将“Id”属性映射为“复合键”,所以我添加了以下映射类:
public class FooMap : ClassMapping<Foo>
{
public FooMap()
{
ComponentAsId(x => x.Id, m =>
{
m.Property(p => p.Bar);
m.Property(p => p.Buzz);
});
}
}
这一切都很不错,但我在下面的查询尝试中遇到错误:
session.QueryOver<Foo>()
.Where(m => m.Id.Bar == "a" &&
m.Id.Buzz == 2).List();
我得到的错误是: NHibernate.QueryException:无法解析属性:Id of:Foo
这很奇怪,因为通过删除基类并将所有内容封装在“Foo”中,它就像一个魅力。 提前谢谢。