我有以下课程:
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 表中,并将附加数据存储在单独的表中。再一次,帐户可以共享地址,但不能共享其他地址数据。