前言
由于刚刚接触mvc不久,之前都是看一些教程学习的,所以一学会(只是皮毛)就非常兴奋的来做mvc的网站,结果做没多久就出现了一个错误
解决方案
当时度娘了找了好久都没找到有效的解决方案,也上了MSDN上看了关于IEntityChangeTracker 的说明,对于我这种菜鸟来说,MSDN讲的实在是太高深莫测,不过还是在MSDN上看到了有用的东西,MSDN的解释是“定义对象服务用于跟踪对象属性更改的功能。”
看字面的意思理解就这东西是用来跟踪的,每出现一个服务对象就跟踪他的属性,看看是否更改,而错误的提示是一个实体对象不能由多个IEntityChangeTracker 实例引用
通俗点理解就是当我们创建了一个实体时,会有引用一个IEntityChangeTracker 实例
而当我们要修改一个实体,当这个实体中又有其他实体存在,就是我们要修改的实体里面引用了其他实体,那时就会有多个IEntityChangeTracker 实例
而在本人的问题中是,在添加一个model对象到数据库时,由于这个model对象有个外键字段,由于少不更事,有对mvc不了解,创建了2个DbContext数据实体类,结果到导致了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();
欢迎各位大侠批评指正