Maison > développement back-end > Golang > Comment interroger efficacement les entités associées dans GORM ?

Comment interroger efficacement les entités associées dans GORM ?

Susan Sarandon
Libérer: 2024-12-29 08:56:11
original
773 Les gens l'ont consulté

How to Efficiently Query Associated Entities in GORM?

Associations dans GORM Golang

Dans Go, en utilisant GORM ORM, un défi courant se pose lors de l'interrogation de plusieurs entités avec des informations associées. Examinons un exemple pour illustrer ce problème.

Considérons les structures représentant une ville et ses lieux associés :

type Place struct {
  ID          int
  Name        string
  Town        Town
}

type Town struct {
  ID   int
  Name string
}
Copier après la connexion

En supposant une base de données avec les exemples de données suivants :

places table towns Table
id name town_id id name
1 Place1 1 1 Town1
2 Place2 1 2 Town2

Pour récupérer tous les lieux ainsi que leurs villes correspondantes, on peut tenter la requête suivante :

db := gorm.Open("sqlite3", "./data.db")
defer db.Close()
places := []Place{}
db.Find(&places)
Copier après la connexion

Cependant, le le résultat donnerait :

[{1 Place1 {0 }} {2 Mares Place2 {0 }}]
Copier après la connexion

Remarquez que les informations correspondantes sur la ville sont manquantes. Pour rectifier cela, il faut spécifier la clé étrangère dans la structure Place comme TownID :

type Place struct {
  ID          int
  Name        string
  Description string
  TownID      int
  Town        Town
}
Copier après la connexion

Pour obtenir le résultat attendu, on pourrait opter pour l'approche suivante :

db.Find(&places)
for i, _ := range places {
    db.Model(places[i]).Related(&places[i].Town)
}
Copier après la connexion

Cela produirait effectivement le résultat souhaité, mais souffre d'un problème n°1, car cela déclenche une requête de base de données supplémentaire pour chaque lieu.

Une solution plus efficace consiste à utiliser Préchargements :

db.Preload("Town").Find(&places)
Copier après la connexion

Cette approche concise aboutit aux requêtes de base de données optimisées suivantes :

SELECT  * FROM "places"
[0.92ms]  SELECT  * FROM "towns"  WHERE ("id" in ('1'))
Copier après la connexion

En utilisant les préchargements, nous garantissons que les informations sur la ville associée sont récupérées dans une seule requête de base de données, ce qui optimiser les performances et éliminer le problème n°1.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal