asp.net-web-api – 首先使用ASP.NET Web API的EF5代码:更新具
发布时间:2020-12-15 20:57:27 所属栏目:asp.Net 来源:网络整理
导读:我正在尝试使用ASP.NET Web API和Entity Framework 5代码优先更新数据库中的客户,但它无法正常工作.我的实体看起来像这样: public class CustomerModel{ public int Id { get; set; } public string Name { get; set; } // More fields public ICollectionC
我正在尝试使用ASP.NET Web API和Entity Framework 5代码优先更新数据库中的客户,但它无法正常工作.我的实体看起来像这样:
public class CustomerModel { public int Id { get; set; } public string Name { get; set; } // More fields public ICollection<CustomerTypeModel> CustomerTypes { get; set; } } public class CustomerTypeModel { public int Id { get; set; } public string Type { get; set; } [JsonIgnore] public ICollection<CustomerModel> Customers { get; set; } } 没有什么特别的.我已经构建了一个Web界面,用户可以通过提供名称和检查一个或多个客户类型来添加客户.点击提交按钮时,数据将发送到我的Web API方法: public void Put([FromBody]CustomerModel customer) { using (var context = new MyContext()) { context.Customers.Attach(customer); context.Entry(customer).State = EntityState.Modified; context.SaveChanges(); } } 这会更新客户字段,但会忽略相关的客户类型.传入的客户对象确实包含应与之关联的CustomerType列表: [0] => { Id: 1,Type: "Finance",Customers: Null },[1] => { Id: 2,Type: "Insurance",Customers: Null } [2] => { Id: 3,Type: "Electronics",Customers: Null } 但是,EF不是查看此列表并添加/删除关联实体,而是忽略它.忽略新关联,即使应删除现有关联,也会保留现有关联. 将客户插入数据库时??遇到了类似的问题,当我将这些实体的状态调整为EntityState.Unchanged时,这个问题得到了解决.当然,我尝试在我的更新场景中应用同样的魔法修复: public void Put([FromBody]CustomerModel customer) { using (var context = new MyContext()) { foreach (var customertype in customer.CustomerTypes) { context.Entry(customertype).State = EntityState.Unchanged; } context.Customers.Attach(customer); context.Entry(customer).State = EntityState.Modified; context.SaveChanges(); } } 但EF继续显示相同的行为. 有想法该怎么解决这个吗?或者我应该只是手动清除CustomerTypes列表,然后手动添加它们? 提前致谢. J.P 解决方法
仅通过设置实体状态无法真正解决这个问题.您必须首先从数据库加载客户,包括其所有当前类型,然后根据已发布客户的更新类型集合从已加载客户中删除类型或添加类型.更改跟踪将完成剩余工作以从连接表中删除条目或插入新条目:
public void Put([FromBody]CustomerModel customer) { using (var context = new MyContext()) { var customerInDb = context.Customers.Include(c => c.CustomerTypes) .Single(c => c.Id == customer.Id); // Updates the Name property context.Entry(customerInDb).CurrentValues.SetValues(customer); // Remove types foreach (var typeInDb in customerInDb.CustomerTypes.ToList()) if (!customer.CustomerTypes.Any(t => t.Id == typeInDb.Id)) customerInDb.CustomerTypes.Remove(typeInDb); // Add new types foreach (var type in customer.CustomerTypes) if (!customerInDb.CustomerTypes.Any(t => t.Id == type.Id)) { context.CustomerTypes.Attach(type); customerInDb.CustomerTypes.Add(type); } context.SaveChanges(); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc – MVC:仅在某些视图上创建模型参数
- asp.net-mvc – 发送asp.net mvc动作结果里面的电子邮件
- asp.net-mvc – 将SignalR与Azure表存储一起使用 – 什么架
- kendo-ui – Kendo grid在最后一页,最后一行位置插入新记录
- ASP.NET WebSite发布与复制?
- asp.net-mvc – 我如何从MVC3 Razor Controller调用webserv
- 如何在asp.net会员中手动更改密码?
- asp.net-mvc – ASP.NET MVC – IsPostBack还在吗?
- asp.net – SQL Server 2005网络IO等待时间(ASYNC_NETWORK_
- asp.net-mvc – 如何在ASP.net MVC 4 RouteConfig.cs中使用
推荐文章
站长推荐
- asp.net-mvc – OData和WebAPI路由冲突
- asp.net-mvc-3 – 将@helper代码转移到App_Code文
- asp.net-mvc – asp.net mvc – 在哪里存储useri
- asp.net-mvc – 将返回文件的长时间运行进程
- asp.net-mvc – ie9:调试时出现恼人的弹出:“错
- 开发自己的Data Access Application Block[上篇]
- asp.net-mvc – 重用MVC视图同时显示数据和编辑数
- ASP.NET 1.1到4.0迁移:事件不工作
- asp.net-web-api – 在ASP.NET Core Web API中实
- asp.net-mvc – 当我用fiddler检查时,VS2013 RTM
热点阅读