Code-First Reference один ко многим - PullRequest
6 голосов
/ 09 февраля 2011

У меня есть следующие две таблицы:

LOCALIZATION

Id                     int
Text                   string

DINER

Id                     int
Name                   string
Description            string
Name_LocalizationID    int
Description_LocationID int

Теперь я хочу, чтобы мой POCO был таким:

public class Diner{
   public int Id{get;set;}
   public ICollection<Localization> NameLocalization{get;set;}
   public ICollection<Localization> DescriptionLocalization{get;set;} 
}

public class Localization{
   public int Id{get;set;}
   public string Text{get;set;}
}

Вопрос: как мы можем сопоставить свойство NameLocalization и DescriptionLocalization с идентификатором локализации с EF Fluent API? Спасибо

Ответы [ 2 ]

3 голосов
/ 09 февраля 2011

SQL Server не поддерживает несколько каскадных удалений, поэтому вам нужно сделать одно из ваших сопоставлений необязательно , чтобы получить схему SQL Server из вашей объектной модели:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<Diner>()
        .HasRequired(diner => diner.NameLocalization)
        .WithMany()
        .IsIndependent()
        .Map(s => 
        { 
            s.MapKey(localization => localization.Id, "NameLocalizationID"); 
        });

    modelBuilder.Entity<Diner>()
        .HasOptional(diner => diner.DescriptionLocalization)
        .WithMany()
        .IsIndependent()
        .Map(s => 
        { 
            s.MapKey(localization => localization.Id, "DescriptionLocationID"); 
        });
}
0 голосов
/ 09 февраля 2011

Боюсь, я не тестировал этот код, но может быть что-то вроде:

modelBuilder.Entity<Diner>()
    .HasRequired(diner => diner.NameLocalization)
    .WithMany().IsIndependent()
    .Map(s => { s.MapKey(localization => localization.Id, "Name_LocalizationID"); });

modelBuilder.Entity<Diner>()
    .HasRequired(diner => diner.DescriptionLocalization)
    .WithMany().IsIndependent()
    .Map(s => { s.MapKey(localization => localization.Id, "Description_LocationID"); });
...