エンティティフレームワークを使用して複合主キーをマッピングするには、2つの方法を使用できます。
1)OnModelCreating()メソッドをオーバーライドする
例:以下に示すように、VehicleFeatureという名前のモデルクラスがあります。
public class VehicleFeature
{
public int VehicleId { get; set; }
public int FeatureId{get;set;}
public Vehicle Vehicle{get;set;}
public Feature Feature{get;set;}
}
私のDBContextのコードは、
public class VegaDbContext : DbContext
{
public DbSet<Make> Makes{get;set;}
public DbSet<Feature> Features{get;set;}
public VegaDbContext(DbContextOptions<VegaDbContext> options):base(options)
{
}
// we override the OnModelCreating method here.
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<VehicleFeature>().HasKey(vf=> new {vf.VehicleId, vf.FeatureId});
}
}
2)データ注釈。
public class VehicleFeature
{
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
public int VehicleId { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Key]
public int FeatureId{get;set;}
public Vehicle Vehicle{get;set;}
public Feature Feature{get;set;}
}
詳細については、以下のリンクを参照してください。
1)https://msdn.microsoft.com/en-us/library/jj591617(v=vs.113 ) .aspx
2)EF 6 Fluent Apiを使用して複合一意キーを追加するにはどうすればよいですか?
SomeId
string
int