【发布时间】:2016-11-18 09:23:52
【问题描述】:
在 Visual Studio 2012 中,我有使用 EF 6 在 SQL DB 中创建和更新条目的 Project#1。
另一个 Project#2 应该只选择从 Project #1 创建/更新的值
两个项目都有一个到本地数据库的连接字符串
两个项目都引用了包含 .edmx 文件和生成的模型的数据访问层库。
http://localhost:1535/Project1: 应该在 支付实体
http://localhost:1896/Project2: 应该从 Payment 中选择值 实体
问题是:当我在不同的本地主机端口上运行这两个应用程序时,我能够创建一个条目并从另一个项目中选择它
但是当我想更新一个条目时,我总是看到 OLD 值。只有当我在 Visual Studio 2012 中重建 Project #2 时,我才能看到更新后的值。
编辑操作
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit([Bind(Prefix = "paymentform")] PaymentForm paymentform)
{
if (ModelState.IsValid)
{
Payment payment = db.Payments.Find(paymentform.formId);
payment.paymenturl = paymentform.paymenturl;
db.Entry(payment).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(new PaymentConfig());
}
发生了什么?
【问题讨论】:
-
是否禁用了对象跟踪?
-
@ViRuSTriNiTy,我不知道你如何启用/禁用它?是否默认设置为true?
-
关于变更检测的非常详细的教程可以在这里找到:blog.oneunicorn.com/2012/03/10/…。此外,您应该启用日志记录以查看在更改付款时是否执行了
UPDATESQL 语句。如果没有,那么对象跟踪很可能被禁用:msdn.microsoft.com/en-us/data/dn469464.aspx -
@ViRuSTriNiTy,我很肯定这些值已更新,因为我可以在从前端更新它们之后直接通过查询数据库直接看到它们。问题在于,当 Project#2 选择值时,我总是看到旧值。对象跟踪仍然是问题吗?
-
请注意,model-view-controller 标签是针对有关模式的问题。 ASP.NET-MVC 实现有一个特定的标记。
标签: c# asp.net asp.net-mvc entity-framework visual-studio