recherche
Maisondéveloppement back-endGolangComment puis-je interroger efficacement des lieux et leurs villes associées à l'aide de GORM dans Go ?

How Can I Efficiently Query Places and Their Associated Towns Using GORM in Go?

Associations GORM Golang ORM : interrogation de lieux avec des villes associées

Dans GORM for Go, il est possible de définir des relations entre modèles, telles que la relation entre les villes et les lieux. Lors de l'interrogation de lieux, il est souvent souhaitable de récupérer également les informations sur la ville associée.

Le problème

Considérez les structures suivantes représentant les villes et les lieux :

type Place struct {
  ID          int
  Name        string
  Town        Town
}

type Town struct {
  ID   int
  Name string
}

Avec un base de données simple contenant deux villes et deux lieux liés à l'une des villes, l'interrogation de tous les lieux peut ne pas donner les résultats escomptés. Au lieu de récupérer des lieux avec leurs informations de ville associées, vous pouvez recevoir un tableau de lieux avec des champs de ville vides.

La solution

Pour interroger correctement les lieux et leurs informations de ville associées, le TownID doit être spécifié comme clé étrangère dans la structure Place :

type Place struct {
  ID          int
  Name        string
  TownID      int
  Town        Town
}

Plusieurs approches peuvent être adoptées pour gérer le interrogation :

Approche 1 : Utilisation de la méthode Related()

places := []Place{}
db.Find(&places)
for i, _ := range places {
    db.Model(places[i]).Related(&places[i].Town)
}

Cette approche déclenche une requête supplémentaire pour chaque lieu pour récupérer la ville associée, ce qui donne un n 1 problème.

Approche 2 :Utilisation Préchargements

L'approche privilégiée consiste à utiliser des préchargements, ce qui permet d'interroger efficacement les modèles associés.

db.Preload("Town").Find(&places)

Cette approche ne déclenche que deux requêtes : une pour récupérer tous les lieux et une pour récupérer tous villes associées.

En utilisant cette approche, la requête renverra le résultat attendu, où chaque objet lieu contient les informations sur la ville associée.

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
Erreurs de journalisation efficacement dans les applications GOErreurs de journalisation efficacement dans les applications GOApr 30, 2025 am 12:23 AM

La journalisation d'erreur d'application GO efficace nécessite d'équilibrer les détails et les performances. 1) L'utilisation de packages de journaux standard est simple mais manque de contexte. 2) Logrus fournit des journaux structurés et des champs personnalisés. 3) ZAP combine les performances et les journaux structurés, mais nécessite plus de paramètres. Un système de journalisation d'erreur complet doit inclure l'enrichissement des erreurs, le niveau de journal, la journalisation centralisée, les considérations de performances et les modes de gestion des erreurs.

Interfaces vides (interface {}) dans Go: cas d'utilisation et considérationsInterfaces vides (interface {}) dans Go: cas d'utilisation et considérationsApr 30, 2025 am 12:23 AM

Vide InterfacesIngoAreInterfaces avec des étages, représentant l'analyse de la valeur et devait être informé de la maintenance

Comparaison des modèles de concurrence: allez par rapport aux autres languesComparaison des modèles de concurrence: allez par rapport aux autres languesApr 30, 2025 am 12:20 AM

Go'sconcurrencyModeLelisunieDuetOtsUseofgoroutinesandChannels, offrant auxquels l'offrand de poids et de la responsabilité approfondie axés

Modèle de concurrence de Go: Goroutines et canaux expliquésModèle de concurrence de Go: Goroutines et canaux expliquésApr 30, 2025 am 12:04 AM

Go'sconcurrencyModeLuSeSGoroutinesandChannelStomageConCurrentProgrammingation efficace.1)

Interfaces et polymorphisme en Go: réutiliser le codeInterfaces et polymorphisme en Go: réutiliser le codeApr 29, 2025 am 12:31 AM

Interfaces andPolymorphisMingoenhanceCodeRelevitality andmainaipability.1) Définir les interfaces de théâtre.

Quel est le rôle de la fonction 'init' dans GO?Quel est le rôle de la fonction 'init' dans GO?Apr 29, 2025 am 12:28 AM

TheinitfonctioningorunsautomAticalement pour que la façon dont la convention est en train

Composition d'interface dans Go: construire des abstractions complexesComposition d'interface dans Go: construire des abstractions complexesApr 29, 2025 am 12:24 AM

Les combinaisons d'interface créent des abstractions complexes dans la programmation GO en décomposant les fonctions en petites interfaces focalisées. 1) Définissez le lecteur, l'écrivain et les interfaces plus étroites. 2) Créez des types complexes tels que le fichier et le réseau de réseaux en combinant ces interfaces. 3) Utilisez la fonction ProcessData pour montrer comment gérer ces interfaces combinées. Cette approche améliore la flexibilité du code, la testabilité et la réutilisabilité, mais il faut prendre soin d'éviter une fragmentation excessive et une complexité combinatoire.

Pièges et considérations potentielles lors de l'utilisation des fonctions d'initiés dans GoPièges et considérations potentielles lors de l'utilisation des fonctions d'initiés dans GoApr 29, 2025 am 12:02 AM

InitisctionsingoaReAutomAticalement compte tenu de la fin de la manière

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

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP