Entity Framework - mise à Jour par l'évolution de la relation de clé étrangère

J'ai les deux modèles suivants et DbContext:

    public class TestDbContext : DbContext
    {
        public IDbSet<Person> People { get; set; }
        public IDbSet<Car> Cars { get; set; }
    }

    public class Person
    {
        public Person()
        {
            ID = Guid.NewGuid();
        }

        public Guid ID { get; set; }
        public string Name { get; set; }
        public virtual List<Car> Cars { get; set; }
    }

    public class Car
    {
        public Car()
        {
           ID = Guid.NewGuid();
        }

        public Guid ID { get; set; }
        public string Name { get; set; }
        public virtual Person Owner { get; set; }
    }

Je puis déclarer une liste de personnes et la liste des voitures, la définition de la propriétaire de la première voiture à la première personne dans la liste:

List<Person> People = new List<Person>()
        {
            new Person() {Name = "bill", ID = new Guid("6F39CC2B-1A09-4E27-B803-1304AFDB23E3")},
            new Person() {Name = "ben", ID = new Guid("3EAE0303-39D9-4FD9-AF39-EC6DC73F630B")}
        };

        List<Car> Cars = new List<Car>() { new Car() { Name = "Ford", Owner = People[0], ID = new Guid("625FAB6B-1D56-4F57-8C98-F9346F1BBBE4") } };   

Je la garde hors de la base de données en utilisant le code suivant et cela fonctionne bien.

using (TestDbContext context = new TestDbContext())
        {
            foreach (Person person in People)
            {
                if (!(context.People.Any(p => p.ID == person.ID)))
                    context.People.Add(person);
                else
                {
                    context.People.Attach(person);
                    context.Entry<Person>(person).State = System.Data.EntityState.Modified;
                }
            }
            foreach (Car caar in Cars)
            {
                if (!(context.Cars.Any(c => c.ID == caar.ID)))
                    context.Cars.Add(caar);
                else
                {
                    context.Cars.Attach(caar);
                    context.Entry<Car>(caar).State = System.Data.EntityState.Modified;
                }
            }
            context.SaveChanges();
        }

Si je puis changer le propriétaire de la voiture pour la deuxième personne et exécutez à nouveau le code, le propriétaire de la Voiture de la propriété n'est pas mis à jour.

Cars[0].Owner = People[1];

Toutes les idées de ce que je fais mal? Merci pour toute aide.

Juste pour ajouter, je suis en train de réaliser ce qui est suggéré stackoverflow.com/questions/9382005/...
Comment avez-vous sauver? Où est le code pour cela? Vous devez recharger Cars de DB et ensuite de le refaire .

OriginalL'auteur user2697817 | 2013-08-19