Lorsque vous utilisez la fonction de suppression de GORM pour supprimer des lignes d'une base de données, il est important de gérer les erreurs potentielles. Bien que la fonction fournie supprime avec succès la ligne spécifiée, elle ne renvoie pas toujours une erreur lors de la tentative de suppression d'une ligne inexistante, ce qui entraîne un comportement inattendu. Pour résoudre ce problème, nous devons vérifier l'état de l'opération de suppression en vérifiant le champ RowsAffected.
<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>
Dans cette fonction révisée, nous vérifions à la fois les erreurs liées à la base de données et l'absence de lignes affectées. Si aucune ligne n'est affectée, cela signifie que la ligne avec l'ID spécifié n'existe pas et une erreur est renvoyée pour l'indiquer. Cette approche permet une gestion plus précise et cohérente des opérations de suppression, garantissant que le comportement souhaité est conservé même dans le cas de lignes inexistantes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!