Для сопоставления составного первичного ключа с использованием Entity framework мы можем использовать два подхода.
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