Golang 開発では、データ操作にデータベースを使用する必要がよくあります。また、実際のビジネスでは、複数のテーブルに対して結合テーブル クエリを実行する必要があることがよくあります。この記事では、golang を使用して複数テーブルの結合クエリを実行する方法を紹介します。
golang では、データベース操作を実行するために ORM ツールをよく使用します。 ORM (Object Relational Mapping) はオブジェクト リレーショナル マッピングであり、リレーショナル データベースのテーブルをオブジェクト指向形式に変換し、データベース操作をより柔軟かつ便利にします。一般的に使用される golang ORM ツールには、GORM、XORM、Beego ORM などが含まれます。ここでは例として GORM を使用します。
次のコマンドを使用して GORM をインストールできます:
go get -u github.com/jinzhu/gorm
結合テーブル クエリを実行する前に、データを定義する必要があります。モデル。データ モデルは、データ操作を容易にするために、リレーショナル データベース テーブルを golang の構造に変換します。たとえば、2 つのテーブルの結合テーブル クエリを実行する必要があります。1 つはユーザー テーブル user、もう 1 つは order テーブル order です。user と order はそれぞれ次の構造として定義できます:
type User struct { Id int Name string } type Order struct { Id int UserId int OrderName string CreateTime time.Time }
このうち、User 構造には、user テーブルの id フィールドと name フィールドに対応する Id と Name の 2 つのフィールドが含まれ、Order 構造には、id に対応する Id、UserId、OrderName、CreateTime の 4 つのフィールドが含まれます。 、user_id、order_name、create_time フィールド。
結合テーブル クエリを実行するときは、2 つのテーブル間の関連付けを定義する必要があります。 GORM は、1 対 1、1 対多、多対 1、多対多の 4 種類の関係を提供します。
たとえば、User と Order の間で多対 1 の関連付けを実行する必要があります。つまり、1 人のユーザーは複数の注文に対応でき、1 つの注文は 1 人のユーザーにのみ対応できます。次のように、Orders フィールドを User 構造に追加して、ユーザーに対応するすべての注文を表すことができます。
type User struct { Id int Name string Orders []Order `gorm:"ForeignKey:UserId"` }
Order 構造では、注文に対応するユーザーを表す User フィールドを追加する必要があります。このうち、Orders フィールドの「ForeignKey:UserId」は、orders テーブルの user_id フィールドが users テーブルの id フィールドに関連付けられており、外部キーとして使用されることを示しています。 users テーブル; User フィールド User in は、このフィールドが User 構造体の Orders フィールドに関連付けられていることを示します。
結合クエリの実行type Order struct { Id int UserId int User User OrderName string CreateTime time.Time }
その中で、Preload("User") は、クエリ時に関連付けに User フィールドを使用することを意味します。 Find(&orders) は、すべての注文をクエリし、それらを order 変数に保存することを意味します。 order[0].User.Nameは、最初に出力されるデータに対応するユーザーのユーザー名を表します。
すべてのユーザーとその対応する注文をクエリする必要がある場合は、次のコードを使用できます:
var orders []Order db.Preload("User").Find(&orders) fmt.Println(orders[0].User.Name) // 输出第一条数据的用户名
その中で、Preload("Orders") は、クエリ時に関連付けに Orders フィールドを使用することを意味します。 , Find(&users ) は、すべてのユーザーをクエリし、それらを users 変数に保存することを意味します。 users[0].Orders[0].OrderNameは、最初のユーザーの最初の注文名を出力することを意味します。
概要
golang を使用して複数テーブルの結合クエリを実行すると、データ モデルを定義し、リレーションシップを定義し、GORM の Preload メソッドを使用することで実装できます。優れたデータ モデルと関係により、データの操作とクエリが容易になります。 GORM の Preload メソッドを使用すると、複数テーブルの結合クエリを簡単に実行できるため、コード量が削減され、コード効率が向上します。
以上がgolang ジョイントテーブルクエリの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。