.net – 传递的主键值的数量必须与实体上定义的主键值的数量相匹
发布时间:2020-12-15 22:35:01 所属栏目:asp.Net 来源:网络整理
导读:我在SQL Server中创建了一个视图,其中包含来自不同表的最重要的列. 将表的内容打印到ASP.NET MVC视图可以正常工作,但是当我想获取单个记录的详细信息时,就会出现问题. The number of primary key values passed must match number of primary key values def
我在SQL Server中创建了一个视图,其中包含来自不同表的最重要的列.
将表的内容打印到ASP.NET MVC视图可以正常工作,但是当我想获取单个记录的详细信息时,就会出现问题.
我导航到这样做的具体记录: @Html.ActionLink("Details","Details",new { id=item.Record_number }) 记录号是主键.我通过右键单击.edmx模型中的特定变量来手动设置它.然后我尝试使用以下内容获取特定数据: // // GET: /Record/Details/5 public ActionResult Details(int id = 0) { try { RecordDataView record = db.RecordDataView.Find(id); //HERE THE ERROR OCCUR if (record == null) { return HttpNotFound(); } return View(record); } catch(EntityException) { return RedirectToAction("NoDatabaseConnection","Home"); } } 模型看起来像这样: namespace Implant.Database { using System; using System.Collections.Generic; public partial class RecordDataView { public int Record_number { get; set; } public Nullable<System.DateTime> DOB { get; set; } public Nullable<System.DateTime> Record_date { get; set; } /** rest of code omitted */ } } 目前我正在使用以下代码使其全部工作.但我不觉得这是一种非常好的方式或效率.而且我很好奇如何解决上面的失败! // // GET: /Record/Details/5 public ActionResult Details(int id = 0) { var record = from r in db.RecordDataView select r; if (id != 0) { record = record.Where(r => r.Record_number == id); } RecordDataView rec = record.ToList().First(); return View(rec); } 有人知道为什么会出现这个错误?感谢帮助! 解决方法
如果在.edmx中设置主键,则应该更新数据库,因为模型中有PK而不是数据库中的PK.更新:不适用于视图.
对于视图,请使用.SingleOrDefault而不是Find(). 在这种情况下,更改以下行:RecordDataView record = db.RecordDataView.Find(id);对于以下内容:RecordDataView recorddataview = db.RecordDataView.SingleOrDefault(m => m.Record_number == id); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc – 避免@html.checkboxfor的foreach
- 在asp.net中是否有等效的回声c#
- ASP.NET页面生命周期解释
- asp.net-mvc – 将隐藏文本字段附加到表单MVC
- .net – 设置页面标题不起作用
- asp.net-mvc – WebService还是一个简单的MVC控制器?
- asp.net-mvc – 无法加载类型’System.Web.Mvc.ViewMasterP
- .net – 为什么我的剃刀视图抱怨“}预计”升级到剃刀2/mvc
- 如何从本地asp.net 4.0 Web应用程序发送支持图像的电子邮件
- LoginView中的ASP.NET LoginStatus不会触发LoggingOut事件
推荐文章
站长推荐
热点阅读