亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在EF中 新增帶外鍵的數據 的寫法

在EF中 新增帶外鍵的數據 的寫法

喵喔喔 2018-12-06 11:43:09
例如: 1 class Employee 2 { 3 Guid Id{get;set;} 4 . 5 . 6 Department department{get;set;} 7 8 } 9 class Department 10 { 11 Guid Id{get;set;} 12 string Name{get;set;} 13 } 14 15 var depart=dbContext.Departments.Find(...);//獲取到一個已存在的Department 16 Employee employee=new {...}; 17 employee.department=depart; 18 19 dbContext.Employees.Add(employee) 20 dbContext.SaveChanges(); 21 22 會報錯 不能在對象“dbo.Department”中插入重復鍵,違反了主鍵約束。 新增Employee對象的時候 ,EF 會去新增一條Department對象。但這個Department對象數據庫已經有了。 報錯了。。 ? 想請問這種情況的正常寫法是怎樣的?
查看完整描述

4 回答

?
手掌心

TA貢獻1942條經驗 獲得超3個贊

[ForeignKey("關系外鍵")] public virtual Department?department{ get; set; } ?試下
查看完整回答
反對 回復 2018-12-09
?
慕容森

TA貢獻1853條經驗 獲得超18個贊

public class Employee { public virtual Department Department { get;set;} } public class Department { public virtual ICollection Employees { get; set; } } // Insert var department = dbContext.Departments.FirstOrDefault(x => ...); if (department != null) { department.Employees.Add(new Employee() { }); } dbContext.SaveChanges(); 你試試行不行? 還有,貼代碼的時候最好貼完整點,不然不好分析問題。
查看完整回答
反對 回復 2018-12-09
  • 4 回答
  • 0 關注
  • 585 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號