0

ドメインの自動マッピングは機能していましたが、NHibernate スタックを更新すると、Session Factory が構成を構築しているときにマッピング例外が発生します。

「多対多のプロパティ 'Users' の反対側がどうあるべきかわかりません。」

多対多マップで例外がスローされる

全体のスタック トレースは次のとおりです。


c:\hornget.horn\orm\fluentnhibernate\Working-2.1\src\FluentNHibernate\Cfg\FluentConfiguration.cs:line 119 の FluentNHibernate.Cfg.FluentConfiguration.BuildConfiguration() で、WebApplication1.NHibernateManager.SessionFactoryManager.BuildConfiguration
(AutoPersistenceModel persistanceModel
)で
C:\WebProgramming\Projects\WebApplication1\WebApplication1\NHibernateManager\SessionFactoryManager.cs:116 行目 C:\WebProgramming\Projects\WebApplication1\WebApplication1\NHibernateManager\SessionFactoryManager.cs:71 行目のWebApplication1.NHibernateManager.SessionFactoryManager.GetSessionFactory (
) WebApplication1.NHibernateManager.SessionManager.CloseSession()


C:\WebProgramming\Projects\WebApplication1\WebApplication1\NHibernateManager\SessionManager.cs: C:\WebProgramming\Projects\WebApplication1\WebApplication1\Global.asax.csの
WebApplication1.Global.Application_EndRequest(オブジェクト送信者、EventArgs e) の47 行目: System.Web.HttpApplication.SyncEventExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() の 36
行 目 System.Web.HttpApplication.ExecuteStep (IExecutionStep step, Boolean& completedSynchronously)



問題は、自動マッピングを使用して多対多の関係を適切に処理する方法です。
注: マッピングは、NHibernate/FluentNHibernate スタックを更新する前に機能していました...

関連する定義を以下に貼り付けます。

ドメイン クラス (Dll 1 内):

public class User : Entity  
{  
// ... removed properties  

    public virtual IList<Role> Roles { get; protected set; }//has many  

// ...  removed methods   
}

public class Role : Entity
{
// ... removed properties  

    public virtual IList<User> Users { get; protected set; }//has many

// ... removed methods  
}

エンティティ クラス (DLL 2 内):

/// <summary>
/// Base Entity deffinition
/// </summary>
public abstract class Entity : IEquatable<Entity>
{
    private int _Id = 0;
    public virtual int Id { get { return _Id; } }

    //... removed methods  
}

規約:

public class PrimaryKeyConvention : IIdConvention
{
    public void Apply(IIdentityInstance instance)
    {
        instance.Column(instance.EntityType.Name + "Id");
        instance.GeneratedBy.HiLo("100");
        instance.Access.ReadOnlyPropertyThroughPascalCaseField(PascalCasePrefix.Underscore);

    }
}


public class ClassConvention : IClassConvention
{
    public void Apply(IClassInstance instance)
    {
        instance.Table(Inflector.Pluralize(instance.EntityType.Name));
        instance.LazyLoad();
        instance.Cache.NonStrictReadWrite();
    }
}  

多対多の規則:

public class ManyToManyConvention : IHasManyToManyConvention
{
    public void Apply(IManyToManyCollectionInstance instance)
    {
        if (instance.OtherSide == null)
        {
            instance.Table(
                string.Format(
                    "{0}To{1}",
                    Inflector.Pluralize(instance.EntityType.Name),
                    Inflector.Pluralize(instance.ChildType.Name)));
            instance.Cascade.AllDeleteOrphan();
        }
        else
        {
            instance.Inverse();
        }
    }

}

モデル:

 var persistanceModel = AutoMap.AssemblyOf<DataModelPaceholder>()
        .AddEntityAssembly(typeof(Entity).Assembly)
        .Conventions.AddFromAssemblyOf<ClassConvention>()
        .UseOverridesFromAssemblyOf<DataModelPaceholder>()
        .Setup(s =>
        {
            s.SubclassStrategy = t => SubclassStrategy.JoinedSubclass;
            s.IsComponentType = type => type == typeof(MoneyComponent);
        })
        .IgnoreBase<Entity>()
        .IgnoreBase<EntityAudit>()
        //.IncludeBase<Product>()
        .Where
        (
            type => typeof(Entity).IsAssignableFrom(type) && !type.IsAbstract
        );
4

1 に答える 1

0

AutoMap の既定の規則に従って、適切な名前の列を持つ UsersToRoles という名前のジャンクション テーブルがありますか? 例 User_id,Role_id ?

于 2010-02-11T15:10:41.200 に答える