前言
由於剛剛接觸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();
歡迎各位大俠批評指正
