Сначала я использую код EF 4.1, и у меня возникают проблемы с обновлением сущности Order, когда существующая сущность содержит ненулевую коллекцию OrderList, а пользователь удалил несколько из существующих и добавил новый список заказов.
У меня есть модель домена, как показано ниже
public class Order
{
public int Id { get; set;
public string Name { get; set;}
public ICollection<OrderList> OrderLists { get; set;}
}
public class OrderList
{
public int Id { get; set;}
public int OrderId { get; set;}
public string ItemDescription { get; set;}
public decimal Price { get; set;}
public virtual Order Order { get; set;}
}
Это код, который я использую для обновления сущности заказа.
using (var context = new MyDbContext())
{
var order = context.Orders
.Include("OrderLists")
.FirstOrDefault(o => o.Id == orderId);
order.Name = "New name"; // this gets saved
order.OrderLists.Clear(); // Does not delete the existing order list items
order.OrderLists = new List<OrderList> { new OrderList { OrderId = order.Id, ItemDescription = "New Item" } }; // Does not create new list
context.Orders.Attach(order);
context.Entry<Order>(order).State = System.Data.EntityState.Modified;
context.ChangeTracker.DetectChanges();
context.SaveChanges();
}
Пожалуйста, объясните мне, как я могу сначала добиться этого, используя код EF 4.1?
Спасибо
Гуру