流利的Nhibernate多对多映射方式

Inf*_*Dev 14 fluent-nhibernate fluent-nhibernate-mapping

我有两个类Order和Items

我想要一个像这样的方法

class Order
{
    public virtual IList<Item> GetItems(Order order)
    {
         //get items for that order.
    }
}
class Item
{
    public virtual IList<Order> GetOrders(Item item)
    {
         //get all the orders in which that items is present.
    }
}
Run Code Online (Sandbox Code Playgroud)

是编写创建这样的方法还是我应该创建一个属性

     public virtual IList<Item> Items { get; set; }
Run Code Online (Sandbox Code Playgroud)

我应该怎么做这个映射是nhibernate?

Chr*_*Wue 33

显然你有一个多对多的关系:一个订单可以有很多项目,一个项目可以属于许多订单.在关系数据库中,你需要用一个我认为你拥有的单独表来表达它 - 让我们假设这个表被调用OrdersItems.

根据Fluent NHibernate文档中的Store/Product示例,您将在以下Items属性OrderOrders属性中创建属性Item:

class Order
{
    public virtual IList<Item> Items { get; protected set; }
}

class Item
{
    public virtual IList<Order> Orders { get; protected set; }
}
Run Code Online (Sandbox Code Playgroud)

和映射:

public class OrderMap : ClassMap<Order>
{
    public OrderMap()
    {
        HasManyToMany(x => x.Items)
           .Cascade.All()
           .Table("OrdersItems");
    }
}

public class ItemMap : ClassMap<Item>
{
    public ItemMap()
    {
        HasManyToMany(x => x.Orders)
           .Cascade.All()
           .Inverse()
           .Table("OrdersItems");
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 我错过了“.Inverse()”,以供将来参考,如果不使用它,“OrdersItems”表会生成双重注册表。 (2认同)