suchen
HeimBackend-EntwicklungGolangWie kann ich mit GORM in Go effizient Orte und die dazugehörigen Städte abfragen?

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

GORM Golang ORM-Assoziationen: Abfragen von Orten mit zugehörigen Städten

In GORM for Go ist es möglich, Beziehungen zwischen Modellen zu definieren, beispielsweise die Beziehung zwischen Städten und Orten. Bei der Abfrage von Orten ist es oft wünschenswert, auch die zugehörigen Ortsinformationen abzurufen.

Das Problem

Betrachten Sie die folgenden Strukturen, die Städte und Orte darstellen:

type Place struct {
  ID          int
  Name        string
  Town        Town
}

type Town struct {
  ID   int
  Name string
}

Mit a B. eine einfache Datenbank mit zwei Städten und zwei Orten, die mit einer der Städte in Zusammenhang stehen, führt die Abfrage aller Orte möglicherweise nicht zu den erwarteten Ergebnissen. Anstatt Orte mit den zugehörigen Stadtinformationen abzurufen, erhalten Sie möglicherweise eine Reihe von Orten mit leeren Stadtfeldern.

Die Lösung

Um Orte und die zugehörigen Stadtinformationen korrekt abzufragen, muss die TownID vorhanden sein als Fremdschlüssel in der Place-Struktur angegeben werden:

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

Es können mehrere Ansätze verfolgt werden, um damit umzugehen Abfragen:

Ansatz 1:Verwendung der Related()-Methode

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

Dieser Ansatz löst eine zusätzliche Abfrage für jeden Ort aus, um die zugehörige Stadt abzurufen, was zu einer n führt 1 Problem.

Ansatz 2:Vorspannungen verwenden

Die Der bevorzugte Ansatz besteht darin, Vorladungen zu verwenden, was eine effiziente Abfrage verknüpfter Modelle ermöglicht.

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

Dieser Ansatz löst nur zwei Abfragen aus: eine zum Abrufen aller Orte und eine zum Abrufen aller zugehörigen Städte.

Mit diesem Ansatz gibt die Abfrage das erwartete Ergebnis zurück, bei dem jedes Ortsobjekt die zugehörigen Stadtinformationen enthält.

Das obige ist der detaillierte Inhalt vonWie kann ich mit GORM in Go effizient Orte und die dazugehörigen Städte abfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Goroutines verstehen: Ein tiefes Eintauchen in die Parallelität von GoGoroutines verstehen: Ein tiefes Eintauchen in die Parallelität von GoMay 01, 2025 am 12:18 AM

GoroutinesareFunctionsOrtheThatrunConcruncurentoingo, aktivieren, dass und leuchtet die Wutzehnung

Verständnis der Init -Funktion in Go: Zweck und VerwendungVerständnis der Init -Funktion in Go: Zweck und VerwendungMay 01, 2025 am 12:16 AM

ThepurpleTheinitfunctioningoinitializeVariables, Setupconfigurationen, orperformN -nötiger SetupBeforeThemaNFunctionexecutes

Verständnis GO -Schnittstellen: Ein umfassender LeitfadenVerständnis GO -Schnittstellen: Ein umfassender LeitfadenMay 01, 2025 am 12:13 AM

GointerfacesAremethodSignaturesSetShattypesMustImplement, EnablingPolymorphism mit der Outinheritanceforcleaner, modularCode.

Erholung von Panik in Go: Wann und wie man recover () verwendet ()Erholung von Panik in Go: Wann und wie man recover () verwendet ()May 01, 2025 am 12:04 AM

Verwenden Sie die Funktion resocal (), um sich von Panik zu erholen. Die spezifischen Methoden sind: 1) Verwenden Sie Recover (), um Panik in der Aufschubfunktion zu erfassen, um Programmabstürze zu vermeiden. 2) detaillierte Fehlerinformationen zum Debuggen aufzeichnen; 3) entscheiden, ob die Programmausführung auf der Grundlage der spezifischen Situation wieder aufgenommen werden soll; 4) Verwenden Sie mit Vorsicht, um die Leistung zu vermeiden.

Wie benutzt man die 'Strings' & quot; Paket, um Saiten in Go zu manipulieren?Wie benutzt man die 'Strings' & quot; Paket, um Saiten in Go zu manipulieren?Apr 30, 2025 pm 02:34 PM

In dem Artikel werden mit dem "Strings" -Paket von Go für String -Manipulationen untersucht, in denen gemeinsame Funktionen und Best Practices beschrieben werden, um die Effizienz zu verbessern und Unicode effektiv zu verarbeiten.

Wie benutzt man den 'Crypto' & quot; Paket zur Durchführung kryptografischer Operationen in Go?Wie benutzt man den 'Crypto' & quot; Paket zur Durchführung kryptografischer Operationen in Go?Apr 30, 2025 pm 02:33 PM

Die Artikeldetails mit dem "Crypto" -Paket von GO für kryptografische Operationen, Erörterung der wichtigsten Generation, des Managements und der Best Practices für die sichere Implementierung.Character Count: 159

Wie benutzt man die 'Zeit' ' Paket zum Umgang mit Daten und Zeiten in Go?Wie benutzt man die 'Zeit' ' Paket zum Umgang mit Daten und Zeiten in Go?Apr 30, 2025 pm 02:32 PM

Der Artikel beschreibt die Verwendung von GO's "Time" -Paket zum Umgang mit Daten, Zeiten und Zeitzonen, einschließlich der aktuellen Zeit, der Erstellung bestimmter Zeiten, der Parsen von Zeichenfolgen und der Messung der verstrichenen Zeit.

Wie benutzt man den 'Reflect' & quot; Paket, um den Typ und den Wert einer Variablen in Go zu überprüfen?Wie benutzt man den 'Reflect' & quot; Paket, um den Typ und den Wert einer Variablen in Go zu überprüfen?Apr 30, 2025 pm 02:29 PM

In Artikel wird das "Reflect" -Paket von GO zur variablen Inspektion und Änderung mithilfe von Methoden und Leistungsüberlegungen erläutert.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.