这个Fluent NHibernate配置出了什么问题?

Nat*_*Roe 2 fluent-nhibernate

以下设置有什么问题?AutoPersistanceModel上的Where过滤器似乎不起作用,并且表名约定似乎也不起作用.我经常得到的错误是"命名空间'urn:nhibernate-mapping-2.2'中的元素'class'在命名空间'urn:nhibernate-mapping-2.2'中有无效的子元素'property'.预期的可能元素列表:命名空间'urn:nhibernate-mapping-2.2'中的'meta,jcs-cache,cache,id,composite-id'." 这是我的代码:

    public ISessionFactory BuildSessionFactory()
    {
        return Fluently.Configure()
            .Database(
                OracleConfiguration.Oracle9.ConnectionString(
                c => c.FromConnectionStringWithKey("ConnectionString")))
            .Mappings(m =>
                          {
                              m.AutoMappings.Add(GetAutoPersistanceModel);
                              m.FluentMappings.AddFromAssembly(Assembly.GetExecutingAssembly());
                          })
            .BuildSessionFactory();
    }

    public AutoPersistenceModel GetAutoPersistanceModel()
    {
        return AutoPersistenceModel.MapEntitiesFromAssemblyOf<User>()
            .Where(type => type.IsClass && !type.IsAbstract && type.Namespace == "Some.Namespace")
            .ConventionDiscovery.Add<IConvention>(
                Table.Is(x => "tbl" + x.EntityType.Name.Pluralize())
            );
    }
Run Code Online (Sandbox Code Playgroud)

Jam*_*ory 6

唯一的例外是说NHibernate <property />首先遇到了一个元素,它是无效的.NHibernate hbm文件中的第一个元素应该(几乎)始终是一个Id,因此似乎AutoPersistenceModel找不到您的标识符.

你的实体如何命名你的ID?本AutoPersistenceModel期望他们从字面上叫编号,如果他们有什么不同,那么它不会找到它们.

您可以使用FindIdentity配置选项覆盖AutoPersistenceModel查找ID的方式,如果您无法修改实体,这可能很有用.

// if your Id is EntityId
.WithSetup(s =>
  s.FindIdentity = property => property.DeclaredType.Name + "Id"
)
Run Code Online (Sandbox Code Playgroud)