golang ジョイントテーブルクエリ
Golang 開発では、データ操作にデータベースを使用する必要がよくあります。また、実際のビジネスでは、複数のテーブルに対して結合テーブル クエリを実行する必要があることがよくあります。この記事では、golang を使用して複数テーブルの結合クエリを実行する方法を紹介します。
- golang の ORM ツールをインストールする
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 フィールドに関連付けられていることを示します。
結合クエリの実行- 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 サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、Goのパッケージインポートメカニズム:名前付きインポート(例:インポート "fmt")および空白のインポート(例:_" fmt")について説明しています。 名前付きインポートはパッケージのコンテンツにアクセス可能になり、空白のインポートはtのみを実行します

この記事では、Webアプリケーションでのページ間データ転送のためのBeegoのnewflash()関数について説明します。 newflash()を使用して、コントローラー間で一時的なメッセージ(成功、エラー、警告)を表示し、セッションメカニズムを活用することに焦点を当てています。 リミア

この記事では、MySQLクエリの結果をGO structスライスに効率的に変換することを詳しく説明しています。 データベース/SQLのスキャン方法を使用して、手動で解析することを避けて強調しています。 DBタグとロブを使用した構造フィールドマッピングのベストプラクティス

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、goで効率的なファイルの書き込みを詳しく説明し、os.writefile(小さなファイルに適している)とos.openfileおよびbuffered write(大規模ファイルに最適)と比較します。 延期エラー処理、Deferを使用し、特定のエラーをチェックすることを強調します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています
