ホームページ >バックエンド開発 >Golang >GORM を使用して自動移行を実行するのに最適な時期はいつですか

GORM を使用して自動移行を実行するのに最適な時期はいつですか

WBOY
WBOY転載
2024-02-08 22:24:341054ブラウズ

何时是使用 GORM 运行 Automigrate 的最佳时机

php Xiaobian Youzi が今日、GORM で自動移行を実行するのに最適なタイミングを共有します。 GORM は、データベース操作を簡素化できる強力な Go 言語 ORM ライブラリです。 Automerge は、GORM が提供する自動移行ツールで、モデル定義に基づいてデータベースのテーブル構造を自動的に生成できます。それでは、GORM を使用して自動移行を実行するのに最適な時期はいつでしょうか?一緒に調べてみましょう。

質問の内容

私がこれまでに見た go/gorm の例のほとんどは、データベース接続を開いた直後に自動移行を呼び出していることを示しています (ここにある gorm ドキュメントも含まれます)。 API サービスの場合、これはすべての API リクエストに対してコストがかかる、または必要な呼び出しです。したがって、API サービスの場合、自動移行は通常のプロセスから削除され、別個に処理されるべきだと思います。私の理解は正しいでしょうか?

gorm ドキュメントより

...
db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{})
if err != nil {
  panic("failed to connect database")
}

// Migrate the schema
db.AutoMigrate(&Product{})
...

回避策

これは、すべての API リクエストで発生するわけではありません。程遠い。これはアプリケーションを起動するたびに発生するため、基本的には、main でデータベースに接続し、そこで automaigrate を実行します。接続を依存関係としてハンドラー/サービス パッケージなど必要なものに渡します。 http ハンドラーはそこにアクセスできます。

基本的には次のとおりです:

リーリー

次に示すように、データベースと対話するためのコードをパッケージに含めます:

リーリー

次に、ハンドラーを賢明な方法で構造化し、リポジトリ (別名 foo パッケージのコンテンツ) を提供します。 リーリー

アプリケーションの更新バージョンをデプロイするたびに、

main 関数が automerge を呼び出し、アプリケーションはデータベースに定期的に再接続したり、何度も再接続したりすることなくリクエストを処理します。再度、移行の処理が 1 回試行されます。

アプリケーションがリクエストごとのセットアップを実行する必要があると考える理由がわかりません。特に、メイン関数 (または

main から呼び出される関数) が明示的に 1 つの http サーバーを作成し、それをリッスンしていることを考えると、リクエスト用の特定のポート。リクエストのリッスンを開始する前に、データベース接続とその後の移行を処理する必要があります。これはリクエストの処理の一部ではありません...

以上がGORM を使用して自動移行を実行するのに最適な時期はいつですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はstackoverflow.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。