10

によって多くのマッピングには多くの3.2私はNHibernate 3.2 built-in mapping by code apiませ FluentNHibernate、またXML)を学ぶためにしようとしています。これらのエンティティ間の多対多の関係をマップしてください。NHibernateのコード

public class Post { 
    public virtual Id { get; set; } 
    public IList<Tag> Tags { get; set; } 
} 

public class Tag { 
    public virtual Id { get; set; } 
    public IList<Post> Posts { get; set; } 
} 

私の主キーの戦略は次のとおりです。

Id( 
    t => t.Id, 
    t => { 
     t.Generator(Generators.HighLow, g => g.Params(new { max_low = 100 })); 
     t.Column(typeof(TEntity).Name + "Id"); 
    }); 

と私はこれ試してみてください。

// TagMap : ClassMapping<Tag> 
Bag(t => t.Posts, bag => { 
    bag.Inverse(true); 
    bag.Table("TagsPosts"); 
    bag.Cascade(Cascade.DeleteOrphans); 
}, t => t.ManyToMany(c => { 
    c.Column("PostId"); 
    c.Lazy(LazyRelation.Proxy); 
})); 

// PostMap : ClassMapping<Post> 
Bag(t => t.Tags, bag => { 
    bag.Table("TagsPosts"); 
    bag.Cascade(Cascade.DeleteOrphans); 
}, t => t.ManyToMany(c => { 
    c.Column("TagId"); 
    c.Lazy(LazyRelation.Proxy); 
})); 

をしかし、それは動作しません。

答えて

27
// Post Map 
Bag(x => x.Tags, collectionMapping => 
       { 
        collectionMapping.Table("TagPosts"); 
        collectionMapping.Cascade(Cascade.None); 
        collectionMapping.Key(k => k.Column("PostID")); 
       }, 
        map => map.ManyToMany(p => p.Column("TagID"))); 

// Tag Map 
Bag(x => x.Posts, collectionMapping => 
             { 
              collectionMapping.Table("TagPosts"); 
              collectionMapping.Cascade(Cascade.None); 
              collectionMapping.Key(k => k.Column("TagID")); 
             }, 
       map => map.ManyToMany(p => p.Column("PostID"))); 
+1

感謝を。できます! Answer Voted up and accepted:D –

+0

カスケードを使用しないことについての説明を追加できますか? – Daniel

1

私はあなたが、それは、このようなものをチェックする必要が多対多のテーブルの上にNHibernateの列を伝えるためのキーに設定する必要があると思う:

// TagMap 
bag.Key(k => k.Column("TagId")); 

// PostMap 
bag.Key(k => k.Column("PostId")); 
関連する問題