Можете ли вы использовать под-свойства навигации во внешних ключах, используя свободный интерфейс EF 4.1? - PullRequest
0 голосов
/ 20 мая 2011

Давайте рассмотрим простой пример:

public class Employee
{
    public int EmployeeID { get; set; }
    public ICollection<Pay> Pays { get; set; }
}

public class Pay
{
    public Employee Employee { get; set; }
    public int Year { get; set; }
    public double Amount { get; set; }
}

Есть ли способ использовать свободный API для создания таблицы Pays с первичным ключом на Employee_EmployeeID, Year (с использованием соглашений по столбцам EF4.1)?

Я не хочу использовать аннотации данных, но я все равно попробовал это:

public class Pay
{
    [Key, Column(Order = 0)]
    public Employee Employee { get; set; }
    [Key, Column(Order = 1)]
    public int Year { get; set; }
    public double Amount { get; set; }
}

Все, что у меня получилось, это первичный ключ на Year и внешний ключ на Employee_EmployeeID.,

1 Ответ

0 голосов
/ 20 мая 2011

Это будет возможно только в том случае, если вы добавите свойство FK к своему Pay:

public class Pay
{
    public int EmployeeId { get; set; }
    public Employee Employee { get; set; }
    public int Year { get; set; }
    public double Amount { get; set; }
}

Теперь вы можете сопоставить его с помощью fluent-api:

modelBuilder.Entity<Pay>()
            .HasKey(p => new 
                {
                    p.EmployeeId,
                    p.Year
                });

Вам нужноФК сотрудника как собственность, если вы хотите сделать ее частью ПК.

...