Asp.Net MVC学习记录之“一个实体对象不能由多个 IEntityChangeTracker 实例引用”


前言

由于刚刚接触mvc不久,之前都是看一些教程学习的,所以一学会(只是皮毛)就非常兴奋的来做mvc的网站,结果做没多久就出现了一个错误

 

解决方案

当时度娘了找了好久都没找到有效的解决方案,也上了MSDN上看了关于IEntityChangeTracker 的说明,对于我这种菜鸟来说,MSDN讲的实在是太高深莫测,不过还是在MSDN上看到了有用的东西,MSDN的解释是“定义对象服务用于跟踪对象属性更改的功能。”

看字面的意思理解就这东西是用来跟踪的,每出现一个服务对象就跟踪他的属性,看看是否更改,而错误的提示是一个实体对象不能由多个IEntityChangeTracker 实例引用

通俗点理解就是当我们创建了一个实体时,会有引用一个IEntityChangeTracker 实例

而当我们要修改一个实体,当这个实体中又有其他实体存在,就是我们要修改的实体里面引用了其他实体,那时就会有多个IEntityChangeTracker 实例

而在本人的问题中是,在添加一个model对象到数据库时,由于这个model对象有个外键字段,由于少不更事,有对mvc不了解,创建了2DbContext数据实体类,结果到导致了2个IEntityChangeTracker 实例被一个DbContext引用,就导致了错误,自个儿摸索了好久才解决

Code

Model

 

 1 //比赛类
 2 public class Competitions
 3 {
 4     public int CompId { set; get; }
 5     public string CompeTitle { set; get; }
 6 }
 7 //学生类
 8 public class Students
 9 {
10     public int StuId { set; get; }
11    public string StuName { set; get; }
12 }
13 //参加比赛类
14 public class Applys
15 {
16     public virtual tbl_Competitions  MatchID { set; get; }
17     public virtual tbl_Students  UserID { set; get; }
18 }

Before

 

 1 //一开始不知道,因为要多次去比赛的详细信息,就图方便写了个方法,结果成了个坑,
 2 //我跳了下去.....
 3 var compe = GetCompetitionById(compid);
 4 Applys apply = new Applys
 5 {
 6          UserID=db.students.FirstOrDefault(id=>id.StudentID==UserId),
 7          MatchID = compe  
 8 };
 9 db.Apply.Add(apply);
10 db.SaveChanges();

 

After

1  var compe = db.competitions.FirstOrDefault(id => id.CompID == compid);
2 Applys apply = new Applys
3 {
4        UserID=db.students.FirstOrDefault(id=>id.StudentID==UserId),
5        MatchID = compe  
6 };
7 db.Apply.Add(apply);
8 db.SaveChanges();

欢迎各位大侠批评指正

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM