ホームページ  >  記事  >  バックエンド開発  >  golang ジョイントテーブルクエリ

golang ジョイントテーブルクエリ

WBOY
WBOYオリジナル
2023-05-10 22:25:061040ブラウズ

Golang 開発では、データ操作にデータベースを使用する必要がよくあります。また、実際のビジネスでは、複数のテーブルに対して結合テーブル クエリを実行する必要があることがよくあります。この記事では、golang を使用して複数テーブルの結合クエリを実行する方法を紹介します。

  1. golang の ORM ツールをインストールする

golang では、データベース操作を実行するために ORM ツールをよく使用します。 ORM (Object Relational Mapping) はオブジェクト リレーショナル マッピングであり、リレーショナル データベースのテーブルをオブジェクト指向形式に変換し、データベース操作をより柔軟かつ便利にします。一般的に使用される golang ORM ツールには、GORM、XORM、Beego ORM などが含まれます。ここでは例として GORM を使用します。

次のコマンドを使用して GORM をインストールできます:

go get -u github.com/jinzhu/gorm
  1. データ モデルの定義

結合テーブル クエリを実行する前に、データを定義する必要があります。モデル。データ モデルは、データ操作を容易にするために、リレーショナル データベース テーブルを 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 フィールド。

  1. 関連付けの定義

結合テーブル クエリを実行するときは、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 フィールドに関連付けられていることを示します。

結合クエリの実行
  1. golang で複数のテーブルの結合クエリを実行する場合、GORM の Preload メソッドを使用できます。 Preload メソッドは、関連付け関係に基づいてすべての関連データをクエリできます。たとえば、すべての注文をクエリして、それに対応するユーザー情報を含める必要がある場合は、次のコードを使用できます:
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 サイトの他の関連記事を参照してください。

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