簡體   English   中英

實體框架外鍵InvalidOperationException

[英]Entity Framework foreign key InvalidOperationException

SaveChanges()調用期間發生InvalidOperationException時,有沒有辦法以某種方式輸出更多細節/信息?

操作失敗:無法更改關系,因為一個或多個外鍵屬性不可為空。 當對關系進行更改時,相關的外鍵屬性將設置為空值。 如果外鍵不支持空值,則必須定義新關系,必須為外鍵屬性分配另一個非空值,或者必須刪除不相關的對象。

我沒有從數據庫中刪除任何內容,所以類似於這個的問題對我沒有幫助。 這條消息是不言自明的,是真的,但我只是看不到代碼中的錯誤,如果異常提供了有關哪個屬性和哪個外鍵有問題的更多信息,那將會有所幫助。

編輯 - 我檢查了InnerException並且它是空的。

例如,如果您有下一個結構:

  public class Client
  {
     public int ClientID { get; set; }
     public string Name { get; set; }

     public int ClientTypeID { get; set; }
     public ClientType ClientType { get; set; }
  }

  public class ClientType
  {
     public int ClientTypeID { get; set; }
     public string Description { get; set; }
  }

例如,如果要更改“名稱”屬性,則屬性“ClientType”必須為null,否則它將嘗試創建,更新或刪除您的客戶端類型。

因此,在SaveChanges()之前將ClientType設置為null;

如果您發布更多代碼,我們可以確定它發生了什么,但這是我的猜測

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM