Error Seeding Database, problem z kluczem obcym

Zbudowałem swoje modele za pomocą POCO. Kiedy idę do mojej bazy danych, otrzymuję:

Nie można określić głównego końca relacji „CSP.Models.Type_Color”. Wiele dodanych elementów może mieć ten sam klucz podstawowy

Oto modele, o których mowa:

public class Type
{
    [Key]
    [ScaffoldColumn(false)]
    public int TypeId { get; set; }

    [Required(ErrorMessage = "A Type Name is Required")]
    [Display(Name="Type")]
    public string Name { get; set; }

    public int ColorId { get; set; }
    public bool Other { get; set; }

    //Navigations
    [ForeignKey("ColorId")]
    public virtual Color Color { get; set; }
    public virtual List<Tools> tools { get; set; }

}

public class Color
{
    [Key]
    [ScaffoldColumn(false)]
    public int ColorId { get; set; }

    [Required(ErrorMessage = "A name is required")]
    public string Name { get; set; }

    public string Description { get; set; }

    //navigation
    public virtual List<Type> Types { get; set; }
}

Większość znaczników zrobiłem po przeczytaniu sugestii.

Mój kod źródłowy, który powoduje błąd, jest tutaj:

var colors = new List<Color>
        {
            new Color{Name="Red"},
            new Color{Name="White"}
        };

            var types = new List<Type>
        {
            new Type{ Name="Hammer", Color = colors.Where(ws => ws.Name=="Red").Single()},
            new Type{ Name= "Electric", Color = colors.Where(ws => ws.Name=="Red").Single()}
        };

new List<Tool>
        {
            new Wine{ Maker= Maker.Single(v => v.Name=="HammerCo"), Type= types.Single(wt => wt.Name=="hammer")},
        }
        }.ForEach(a => context.Tools.Add(a));
            context.SaveChanges();

Próbowałem również dodać każdą wartość do kontekstu, a następnie zapisać. Ten błąd wystąpił po próbie zapisania encji typu:

[System.Data.SqlClient.SqlException] = {"Instrukcja INSERT jest sprzeczna z ograniczeniem FOREIGN KEY" Type_Color ". Konflikt wystąpił w bazie danych" TestTools ", tabela" dbo.Colors ", kolumna 'ColorId n Instrukcja została zakończona.

czego mi brakuje?

questionAnswers(1)

yourAnswerToTheQuestion