1

gorm ORMを使用して、小さくてシンプルな Web アプリを書いています。

データベースは Web アプリケーションとは関係なく失敗する可能性があるため、Web アプリケーションを再起動せずにデータベースに再接続できるように、このケースに対応するエラーを識別できるようにしたいと考えています。

動機付けの例:

次のコードを検討してください。

var mrs MyRowStruct
db := myDB.Model(MyRowStruct{}).Where("column_name = ?", value).First(&mrs)
return &mrs, db.Error
  1. そのdb.Error != nil場合、エラーがデータベース接続の問題に起因しているかどうかをプログラムで判断するにはどうすればよいですか?

  2. 私の読書から、それは接続を表してgorm.DB いないgorm.Openことを理解しているので、データベース接続が失敗した場合に再接続または呼び出しを再発行することについて心配する必要さえありますか?

  3. Go でデータベース障害を処理するための一般的なパターンはありますか?

4

1 に答える 1