10

sto cercando di imparare NHibernate 3.2 built-in mapping by code api (NON FluentNHibernate, nè xml). Puoi aiutarmi a mappare una relazione molti-a-molti tra queste entità per favore?NHibernate 3.2 molti a molti mappatura dal codice

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; } 
} 

La mia strategia chiave primaria è:

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

e provo questo:

// 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); 
})); 

ma non funziona.

risposta

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

Grazie. Funziona! Risposta Votata e accettata: D –

+0

Puoi aggiungere qualche spiegazione per non utilizzare alcun collegamento a cascata? – Daniel

1

penso che è necessario impostare la chiave per raccontare NHibernate quale colonna sul tavolo molti-a-molti è bisogno di controllare, qualcosa di simile:

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

// PostMap 
bag.Key(k => k.Column("PostId"));