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 フィールドは nil のままです。

この動作を変更し、存在しない行に対してエラーを返すには、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 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!