Maison >développement back-end >Golang >Comment gérer les erreurs lors de la suppression de lignes avec la fonction de suppression de GORM ?

Comment gérer les erreurs lors de la suppression de lignes avec la fonction de suppression de GORM ?

DDD
DDDoriginal
2024-10-27 01:03:021103parcourir

How to Handle Errors When Deleting Rows with GORM's Delete Function?

Dépannage des erreurs de la fonction de suppression de GORM

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn