golang関連のクエリ

WBOY
WBOYオリジナル
2023-05-10 09:03:06872ブラウズ

はじめに

インターネットの普及とデータ量の増加に伴い、データを効率的にクエリする方法が多くの開発者の焦点になっています。ソフトウェア開発では、相関クエリは非常に一般的なシナリオです。この記事では、golang に関連するクエリ方法を紹介することで、読者に高速かつ効率的なクエリ方法を提供します。

1. 関連クエリとは何ですか?

連想クエリとは、複数のデータ テーブル間の関係を通じてクエリを実行する方法を指します。クエリでは、あるテーブルの特定の列を別のテーブルの特定の列と比較して、クエリが必要な結果を取得します。一般的な関係には、1 対 1、1 対多、多対多などが含まれます。

たとえば、従業員テーブルと部門テーブルという 2 つのデータ テーブルがあるとします。従業員テーブルと部門テーブルには、従業員と部門との関係があります。各従業員は部門に所属しているため、従業員テーブルと部門テーブル間の関連付けられたクエリを通じて、従業員情報と部門情報を同時に取得できます。

2. golang の関連クエリ方法

golang では、ORM ツールを使用して関連クエリを実行できます。この記事では、gorm を例として、golang の関連クエリを紹介します。

  1. 1 対 1 関連クエリ

golang では、1 対 1 の関係とは、2 つのデータ テーブル内のデータの各行が、 other テーブル内のデータの行。 golang を使用して 1 対 1 の関連クエリを実行する場合、物理外部キーまたは仮想外部キーを通じて実装できます。

(1) 物理外部キー

物理外部キーは、関連する 2 つのテーブル間の、一方のテーブルの列の値に対応する、もう一方のテーブルの列の値を指します。 。 golang では、構造を定義することで 1 対 1 の相関クエリを完成させることができます。たとえば、従業員と部門という 2 つの異なる構造があるとします。コードは次のとおりです:

type Employee struct {
      ID          int
      Name        string
      HireDate    time.Time
      Department  Department
}

type Department struct {
      ID          int
      Name        string
      Description string
}

従業員構造では、部門構造を定義することで 1 対 1 の関連クエリを実行します。このメソッドでは、関連付けられたクエリを実装するためにクエリを実行するときに Joins() メソッドを使用する必要があります。たとえば、従業員情報と部門情報をクエリする必要がある場合、コードは次のとおりです。

var employee Employee
db.Joins("Department").Find(&employee)

(2) 仮想外部キー

仮想外部キーとは、必要に応じてプログラムを実行します。 golang では、リレーションシップ フィールドを追加し、テーブル A をテーブル B の関連テーブルとして使用することで、1 対 1 の相関クエリを完成させることができます。たとえば、従業員情報と会社情報をクエリする必要がある場合、コードは次のとおりです:

type Employee struct {
      ID          int
      Name        string
      HireDate    time.Time
      CompanyID   int
}

type Company struct {
      ID          int
      Name        string
      Description string
}

var employee Employee
var company Company
db.Model(&employee).Related(&company, "CompanyID")
  1. 1 対多の関連付けクエリ

1 対多くの関係は 2 つのデータ テーブル間の関係を指し、1 つのテーブルの 1 行のデータが別のテーブルの複数行のデータに対応することがあります。 golang では、Slice を定義することで 1 対多の関連付けクエリを完了できます。たとえば、Department と Employee という 2 つの異なる構造があるとします。コードは次のとおりです:

type Department struct {
      ID          int
      Name        string
      Description string
      Employees   []Employee
}

type Employee struct {
      ID          int
      Name        string
      HireDate    time.Time
      DepartmentID int
}

var department Department
db.Preload("Employees").Find(&department)

Department 構造では、Employees スライスを定義することで 1 対多の関連クエリを実行します。クエリを実行するときは、Preload() メソッドを使用して関連するクエリを実行する必要があります。

  1. 多対多の関連付けクエリ

多対多の関係とは、2 つのデータ テーブルで、1 つのデータ行が複数のデータ行に対応できることを意味します。複数のテーブルで同時に。 golang では、配列を定義することで多対多のリレーショナル クエリを完了できます。たとえば、Product と category という 2 つの異なる構造があるとします。コードは次のとおりです:

type Product struct {
      ID         int
      Name       string
      Categories []Category `gorm:"many2many:ProductCategories;"`
}

type Category struct {
      ID   int
      Name string
}

var product Product
db.Preload("Categories").Find(&product)

Product 構造では、Categories 配列を定義することで多対多の関連クエリを完了します。クエリを実行するときは、Preload() メソッドを使用して関連するクエリを実行する必要があります。

結論

この記事では、1 対 1、1 対多、多対多のリレーションシップを含む、golang の関連するクエリ メソッドを紹介しました。この記事の方法を学ぶことで、読者は golang で関連するクエリをより簡単に実行できるようになり、データを効率的にクエリしながらクエリの効率を向上させることができます。

以上がgolang関連のクエリの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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