recherche
Maisondéveloppement back-endGolangComment interroger efficacement les entités associées dans GORM ?

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
}

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)

Cependant, le le résultat donnerait :

[{1 Place1 {0 }} {2 Mares Place2 {0 }}]

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
}

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)
}

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)

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'))

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!

Déclaration
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
Tapez des assertions et des commutateurs de type avec des interfaces GOTapez des assertions et des commutateurs de type avec des interfaces GOMay 02, 2025 am 12:20 AM

GohandlesInterfaces etTypeAssertionSEffectively, EnhancingCodeFlexibilityAndRobustness.1) TypeAssertionsallowruntimeTypeCHecking, asseenwithheshapeInterfaceandCirctleTy.2)

Utilisation d'erreurs.Utilisation d'erreurs.May 02, 2025 am 12:11 AM

GO Language Les erreurs de la langue deviennent plus flexibles et lisibles via Errors.is et Errors. Comme fonctions. 1.Errors.is est utilisé pour vérifier si l'erreur est la même que l'erreur spécifiée et convient au traitement de la chaîne d'erreur. 2. ERRORS. As peut non seulement vérifier le type d'erreur, mais également convertir l'erreur en un type spécifique, ce qui est pratique pour extraire les informations d'erreur. L'utilisation de ces fonctions peut simplifier la logique de gestion des erreurs, mais faire attention à la livraison correcte des chaînes d'erreur et éviter une dépendance excessive pour éviter la complexité du code.

Tableau des performances dans Go: Optimiser vos applicationsTableau des performances dans Go: Optimiser vos applicationsMay 02, 2025 am 12:06 AM

TomakeGoapplicationsRunfasterandMoreEfficiently, useProfilingTools, LeverageConcurrency et ManageMemoryEffective.1) useProfforcpuandMemoryProfilingtodentifyBottleneck

L'avenir de Go: Tendances et développementsL'avenir de Go: Tendances et développementsMay 02, 2025 am 12:01 AM

GO'sfutureisbrightwithTrends like improvedtooling, génériques, cloud-nativeadoption, performanceenhancements et webassembly integration, butchallengeSincludemainainingImPlicityAnd Improverrorror.

Comprendre les Goroutines: une plongée profonde dans la concurrence de GoComprendre les Goroutines: une plongée profonde dans la concurrence de GoMay 01, 2025 am 12:18 AM

GoroutinesaConctionnement est en train de savoir-faire, en permettant à la croissance de la pondération.1).

Comprendre la fonction d'init en Go: but et utilisationComprendre la fonction d'init en Go: but et utilisationMay 01, 2025 am 12:16 AM

La poursuite de la théorie des fonctionnalités, les réglementations de configurations, l'orperformance a été utile, utilise-to-nection des fonctionnalités.

Comprendre les interfaces GO: un guide completComprendre les interfaces GO: un guide completMay 01, 2025 am 12:13 AM

GoInterfaceSareMethodsignatisesetSeTyPesmustimplement, permettant de permettre à la transfert depolymorphisms avec une information pour laCleaner, modularCode.Eplicite Implicitement satisfait, utile pour lesquelleserrorSandDeCoupling, ButrequireCarefusetoavoidRumeerRorroSedMaintAntainTaidTaipTyPesafety.

Récupérer des paniques en Go: quand et comment utiliser Recover ()Récupérer des paniques en Go: quand et comment utiliser Recover ()May 01, 2025 am 12:04 AM

Utilisez la fonction Recover () dans GO pour récupérer de la panique. Les méthodes spécifiques sont: 1) Utiliser Recover () pour capturer la panique dans la fonction de différence pour éviter les accidents du programme; 2) Enregistrer les informations d'erreur détaillées pour le débogage; 3) Décidez de reprendre l'opportunité de reprendre l'exécution du programme en fonction de la situation spécifique; 4) Utiliser avec prudence pour éviter d'affecter les performances.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP