


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!

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.

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

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

Go'sconcurrencyModeLuSeSGoroutinesandChannelStomageConCurrentProgrammingation efficace.1)

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

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

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.

InitisctionsingoaReAutomAticalement compte tenu de la fin de la manière


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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 !

Article chaud

Outils chauds

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

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
Puissant environnement de développement intégré PHP

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
Puissant environnement de développement intégré PHP
