如何处理 Delete 函数中的 GORM 错误?
How to handle GORM error at Delete function?
我有这个功能:
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
消息,但它总是 return 无:
result.Error: <nil>
*我正在为数据库使用 postgreSQL
尝试删除不存在的行不 SQL 标准认为是错误。如果你需要return一个错误,你应该检查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
}
我有这个功能:
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
消息,但它总是 return 无:
result.Error: <nil>
*我正在为数据库使用 postgreSQL
尝试删除不存在的行不 SQL 标准认为是错误。如果你需要return一个错误,你应该检查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
}