(Utilisation d'Entity Framework 6.2)
J'ai les deux modèles / entités suivants:
public class City
{
public int CityId { get; set; }
public string Name { get; set; }
}
public class Country
{
public Country()
{
Cities new HashSet<City>();
}
public int CountryId { get; set; }
public string Name { get; set; }
public virtual ICollection<City> Cities { get; set; }
}
Et le DbContext suivant
public DbSet<Country> Countries { get; set; }
Ma question est la suivante: si les enfants de l'objet Pays changent (par exemple, les villes), comment puis-je le mettre à jour?
Puis-je faire ceci:
List<City> cities = new List<City>();
// Add a couple of cities to the list...
Country country = dbContext.Countries.FirstOrDefault(c => c.CountryId == 123);
if (country != null)
{
country.Cities.Clear();
country.Cities = cities;
dbContext.SaveChanges();
}
Cela fonctionnerait-il? Ou devrais-je ajouter spécifiquement chaque ville? c'est à dire:
List<City> cities = new List<City>();
// Add a couple of cities to the list...
Country country = dbContext.Countries.FirstOrDefault(c => c.CountryId == 123);
if (country != null)
{
country.Cities.Clear();
foreach (City city in cities)
country.Cities.Add(city);
dbContext.SaveChanges();
}
Vous devez ajouter des Cities
à cet objet Country
particulier en cours de mise à jour.
public Country Update(Country country)
{
using (var dbContext =new DbContext())
{
var countryToUpdate = dbContext.Countries.SingleOrDefault(c => c.Id == country.Id);
countryToUpdate.Cities.Clear();
foreach (var city in country.Cities)
{
var existingCity =
dbContext.Cities.SingleOrDefault(
t => t.Id.Equals(city.cityId)) ??
dbContext.Cities.Add(new City
{
Id = city.Id,
Name=city.Name
});
countryToUpdate.Cities.Add(existingCity);
}
dbContext.SaveChanges();
return countryToUpdate;
}
}
Mettre à jour :
public class City
{
public int CityId { get; set; }
public string Name { get; set; }
[ForeignKey("Country")]
public int CountryId {get;set;}
public virtual Country Country {get; set;}
}
J'espère que cela aide.