首頁 >後端開發 >C++ >為什麼使用 Entity Framework 6 更新記錄有時會導致「受影響的行數意外」?

為什麼使用 Entity Framework 6 更新記錄有時會導致「受影響的行數意外」?

Barbara Streisand
Barbara Streisand原創
2025-01-07 08:26:40574瀏覽

Why Does Updating Records with Entity Framework 6 Sometimes Result in

使用 Entity Framework 6 更新記錄

本文解決了使用 Entity Framework 6 更新記錄的挑戰。提供的程式碼檢索記錄以更新並嘗試將其附加到上下文,然後將其狀態設為已修改並儲存變更。但是,遇到錯誤,表示受影響的行數超出預期。

解決方案

該錯誤表明您嘗試更新的記錄可能有自您檢索以來已被修改。要解決此問題,您應該直接從資料庫上下文檢索對象,然後在儲存之前進行必要的變更。

這是程式碼的修訂版本:

using (var db = new MyContextDB())
{
    var result = db.Books.SingleOrDefault(b => b.BookNumber == bookNumber);
    if (result != null)
    {
        result.BookName = _book.BookName;

以上是為什麼使用 Entity Framework 6 更新記錄有時會導致「受影響的行數意外」?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn