首页 > 解决方案 > 如何在删除函数中处理 GORM 错误?

问题描述

我有这个功能:

var db *gorm.DB

func DeleteCategory(id uint) error {
    var category Category
    category.ID = id
    result := db.Delete(&category)
    fmt.Println("result.Error: ", result.Error)
    return result.Error
}

这个函数应该删除数据库中的行,它是,但是当我用相同的 id 多次调用这个函数时,我希望它error在第二次调用时抛出消息,但它总是返回 nil: result.Error: <nil> *我正在使用 postgreSQL数据库

标签: gogo-gorm

解决方案


尝试删除不存在的行不SQL 标准视为错误。如果需要返回错误,您应该检查该RowsAffected字段。

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
}

推荐阅读