0

我有以下课程:

public class Account
{
   public int Id {get; set;}
   public ICollection<AccountAddress> Addresses {get; set;}
}

public class Address 
{
   public int Id {get; set;}
   public string Street1 {get; set;}
   ... //Other address properties
}

public class AccountAddress : Address
{
   public int AccountId {get; set;}
   public DateTime BeginDate {get; set;}
   public DateTime PurgeDate {get; set;}
   public bool IsPrimary {get; set;}
}

在我流利的 ​​api 配置中,我有以下内容:

public AccountConfiguration()
{
    ToTable("accounts");
    HasKey(m => m.Id);
    Property(m => m.Id).HasColumnName("accountid");
    ...
    //This is wrong because it does not allow many to many
    HasMany(m => m.Addresses).WithRequired().HasForeignKey(m => m.AccountId);
}

public AddressConfiguration()
{
   ToTable("addresses");
   HasKey(a => a.Id);
   Property(a => a.Id).HasColumnName("addressid");
   ...
}

public AccountAddressConfiguration()
{
   ToTable("acctaddrs");
   HasKey(m => new {m.Id, m.AccountId});
   ...
}

我正在尝试将我的 AccountConfiguration 上的关系编辑为多对多关系,但我正在努力弄清楚如何定义它。

这背后的想法是账户可以有多个地址,一些账户可以绑定到同一个地址。

感谢您对此的帮助!

编辑 所以这是我需要完成的。我有一个表(地址),它有一个 Id 字段并存储您所有的典型地址信息。还有许多其他表具有指向 Addresses 表中的地址的 AddressId 字段。单个地址可以被许多不同的关系重用。

现在,一个帐户有许多地址,但也有关于一个地址的附加数据。我想要完成的是将地址数据存储在 Addresses 表中,并将附加数据存储在单独的表中。再一次,帐户可以共享地址,但不能共享其他地址数据。

4

1 回答 1

0

您不能将其建模为多对多关联(使用透明联结表),因为联结表AccountAddress不仅包含主键值。

作为一个真正的联结表AccountAddress还应该包含AddressId

public class AccountAddress : Address
{
   [ForeignKey("Account"]] // Or fluent mapping
   public int AccountId {get; set;}
   public virtual Account Account {get; set;}

   [ForeignKey("Address"]] // Or fluent mapping
   public int AddressId {get; set;}
   public virtual Address Address {get; set;}

   public DateTime BeginDate {get; set;}
   public DateTime PurgeDate {get; set;}
   public bool IsPrimary {get; set;}
}

并且您的帐户和地址类都应该有一个ICollection<AccountAddress>.

您将其映射为Address 1 - n AccountAddress n - 1 Account.

要获取例如帐户地址,请执行以下操作:

Accounts.Select(a => a.AccountAddresses
                     // .Where(a => a.IsPrimary // for instance
                      .Select(aa => aa.Address))
于 2013-02-04T21:57:12.107 回答