也许是一个简单的问题,但我似乎无法弄明白。将模型添加到数据库时将集合保存到模型不起作用。我有一个使用asp.net MVC和实体框架的网站。
模特:
public class Event
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public ICollection<EventRange> Ranges { get; set; }
}
public class EventRange
{
public int Id { get; set; }
public string RangeName { get; set; }
public string RangeDescription { get; set; }
public int Capacitiy { get; set; }
}
控制器操作:
[HttpPost]
public ActionResult Create(Event model)
{
ICollection<EventRange> eventRanges = new Collection<EventRange>();
var range = new EventRange {RangeName = "testrange", RangeDescription = "test", Capacitiy = 5}
eventRanges.Add(range);
model.Ranges = eventRanges;
db.Events.Add(model);
db.SaveChanges();
return View();
}
public ActionResult Events()
{
return View(db.Events);
}
在“事件”操作中设置断点并评估查询时,“范围”不会保存到事件中:
请注意,EF为事件范围模型创建的数据库确实保存了范围:
我做错了吗?
答案 0 :(得分:0)
如果您将Ranges
属性标记为virtual
public virtual ICollection<EventRange> Ranges { get; set; }