我有以下情况,流利的nhibernate:
public class Stuff
{
public Stuff()
{
Entities = new List<Entity>();
}
public virtual int Id { get; set; }
public virtual IList<Entity> Entities { get; set; }
}
public abstract class Entity
{
public virtual int Id { get; set; }
public virtual string Type { get; set; }
public virtual Stuff Stuff { get; set; }
}
public class Person : Entity
{
public virtual string FirstName { get; set; }
public virtual string LastName { get; set; }
}
public class Animal : Entity
{
public virtual string Species { get; set; }
}
然后,我有以下代码来使用automap并生成这些映射:
var sessionFactory =
Fluently.Configure().Database(persistenceConfigurer).Mappings(
m =>
m.AutoMappings.Add(
AutoMap.Source(new Types(typeof(Entity), typeof(Person), typeof(Animal), typeof(Stuff))))
.ExportTo(@"e:\")).ExposeConfiguration(BuildSchema).BuildSessionFactory();
然而,发生的事情是我得到以下异常:
---&GT; NHibernate.MappingException:关联引用未映射的类:ConsoleApplication1.Models.Entity
如果我使实体类非抽象,这是有效的,但是,我想避免在数据库中使用该表但仍然使用re维护层次结构概念
答案 0 :(得分:2)
您需要像这样添加自动映射
AutoMap.AssemblyOf<Entity>(yourConfiguration).IgnoreBase<Entity>();
这不仅会忽略您的Entity
基类,而且只要每个模型都继承自Entity
,您就不需要手动添加每个实体。