首頁 > 後端開發 > Golang > 主體

如何在 GORM 的刪除功能中處理不存在的行?

Mary-Kate Olsen
發布: 2024-10-27 10:26:30
原創
992 人瀏覽過

How to Handle Non-Existent Rows in GORM's Delete Function?

處理 GORM 刪除函數中的錯誤

使用 GORM 進行資料庫刪除時,考慮如何處理不存在的資料至關重要行。預設情況下,GORM 在嘗試刪除不存在的行時不會拋出錯誤。相反,result.Error 欄位保持為零。

要更改此行為並為不存在的行傳回錯誤,您需要檢查 RowsAffected 欄位。以下是修改DeleteCategory函數的方法:

<code class="go">func DeleteCategory(id uint) error {
    c := Category{ID: id}

    db := db.Delete(&c)
    if db.Error != nil {
        return db.Error
    } else if db.RowsAffected < 1 {
        return fmt.Errorf("row with id=%d cannot be deleted because it doesn't exist", id)
    }

    return nil
}</code>
登入後複製

在此修改後的函數中:

  1. 呼叫GORM的Delete方法,將結果指派給db。
  2. 如果db.Error不為nil,則回傳錯誤。
  3. 確認沒有一般錯誤後,檢查db.RowsAffected。如果小於 1,表示沒有行受到刪除操作的影響,則傳回自訂錯誤訊息。
  4. 如果行刪除成功,則傳回 nil 錯誤值。

以上是如何在 GORM 的刪除功能中處理不存在的行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!