ホームページ >バックエンド開発 >Golang >GORM 2.0 で最後に挿入された ID を取得する方法は?

GORM 2.0 で最後に挿入された ID を取得する方法は?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-25 11:55:021137ブラウズ

How to Retrieve the Last Inserted ID in GORM 2.0?

GORM 2.0 の最終挿入 ID

GORM 2.0 では、データベース挿入の実行後に最後に挿入された ID の取得が以前と比べて変更されました。バージョン。この記事では、現在のバージョンの GORM を使用して最後に挿入された ID を取得する方法について説明します。

GORM v2.0 では、Begin() 関数は、以前は LastInsertId( を提供していた) sql.Tx オブジェクトを返さなくなりました。 ) 方法。代わりに、データベースに行を挿入した後に Last() 関数を使用する必要があります。あるいは、より効率的なアプローチも利用できます。

Create 関数を使用してデータベースの挿入が成功すると、GORM は関数に渡されたモデルに ID を自動的に設定します。したがって、モデルには最後に挿入された ID がすでに含まれているため、db.Last(&model) を呼び出す必要はありません。この手法により、不必要なデータベース呼び出しが回避されるだけでなく、データの整合性も確保されます。

これを示すために、次の例を考えてみましょう。

<code class="go">type User struct {
    gorm.Model
    Name string
}

user1 := User{Name: "User One"}

_ = db.Transaction(func(tx *gorm.DB) error {
    tx.Create(&user1)
    return nil
})

// This is unnecessary
// db.Last(&user1)

fmt.Printf("User one ID: %d\n", user1.ID)</code>

この例では、user1 モデルには最後に挿入されたデータが自動的に含まれます。 Create 関数を実行した後の ID。user1.ID を使用して直接アクセスできます。この方法は効率的であり、追加のデータベース クエリや不要な関数呼び出しの必要がなくなります。

以上がGORM 2.0 で最後に挿入された ID を取得する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。