


Gorm ruft alle Daten aus der Tabelle basierend auf dem Zustand der verschachtelten Tabelle ab
PHP-Editor Xigua stellt Ihnen eine effiziente Datenerfassungsmethode vor – Gorm. Gorm ist eine Golang-basierte ORM-Bibliothek, die die Interaktion mit Datenbanken erleichtert. Wenn wir Gorm verwenden, können wir alle Daten aus der Tabelle basierend auf den Bedingungen der verschachtelten Tabelle abrufen, ohne langwierige manuelle Abfragen. Diese Methode vereinfacht nicht nur den Code, sondern verbessert auch die Abfrageeffizienz, sodass Entwickler Daten bequemer verwalten können. Sowohl Anfänger als auch erfahrene Entwickler können mit Gorm problemlos Datenerfassungsfunktionen implementieren.
Frageninhalt
Ich habe eine Tabelle mit der folgenden Golang-Struktur:
order { id transactionid transaction } transaction { id profileid profile } profile { id accountid account }
Wie erhalte ich alle Bestellungen mit Konto-ID-Bedingungen über Gorm? Ich habe es versucht:
var orders []*Order res := r.db. Joins("Transaction"). Preload("Transaction.Profile"). Where("Transaction.Profile.account_id = 1"). Find(&orders)
Aber es funktioniert nicht.
Workaround
Die Lösung sollte basierend auf der von Ihnen bereitgestellten Strukturdefinition funktionieren. Lassen Sie mich Ihnen zuerst den Code zeigen und dann gehe ich jeden Schritt durch:
package main import ( "fmt" _ "github.com/lib/pq" "gorm.io/driver/postgres" "gorm.io/gorm" ) type Order struct { Id int TransactionId int Transaction Transaction } type Transaction struct { Id int ProfileId int Profile Profile } type Profile struct { Id int AccountId int Account Account } type Account struct { Id int } func main() { dsn := "host=localhost user=postgres password=postgres dbname=postgres port=5432 sslmode=disable" db, err := gorm.Open(postgres.Open(dsn), &gorm.Config{}) if err != nil { panic(err) } db.AutoMigrate(&Account{}) db.AutoMigrate(&Profile{}) db.AutoMigrate(&Transaction{}) db.AutoMigrate(&Order{}) db.Create(&Account{}) db.Create(&Profile{AccountId: 1}) db.Create(&Transaction{ProfileId: 1}) db.Create(&Order{TransactionId: 1}) // order + transaction + profile + account var order Order db.Debug().Preload("Transaction.Profile.Account").Joins("inner join transactions t on orders.transaction_id = t.id").Joins("inner join profiles p on p.id = t.profile_id").Joins("inner join accounts a on p.account_id = a.id").First(&order, "a.id = ?", 1) fmt.Println(order) }
Schauen wir uns den Code genauer an.
Strukturdefinition
Hier hat sich nichts geändert. Stellen Sie beim Deklarieren einer Struktur sicher, dass Sie die Gorm-Konventionen verstehen, da Gorm darauf basierend Beziehungen, Fremdschlüssel und Einschränkungen erstellt.
Datenbank vorbereiten
Hier finden Sie die Verbindung zu Postgres, den automatischen Migrationsbefehl zum Synchronisieren von Tabellen und das Einfügen einiger Dummy-Daten.
Abfrage
Hier verwenden wir viele Methoden, die im Gorm-Paket von go bereitgestellt werden. Sehen wir sie uns in einer kurzen Liste an:
-
debug
: Es gibt die Roh-SQL-Abfrage an die Konsole aus. Sehr nützlich bei der Bearbeitung komplexer Anfragen -
preload
: Laden Sie verwandte Entitäten, schließen Sie sie jedoch nicht in die endgültige von gorm generierte Abfrage ein -
joins
:它指定在 join 子句中必须引用哪些表。使用joins
Wir fügen diese Klausel zur Abfrage hinzu. -
first
:它既用于仅获取一条记录,也用于指定一些过滤器,例如我们的例子(例如a.id = ?
).
Wenn das Ihr Problem löst, lassen Sie es mich bitte wissen, vielen Dank!
Das obige ist der detaillierte Inhalt vonGorm ruft alle Daten aus der Tabelle basierend auf dem Zustand der verschachtelten Tabelle ab. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

In diesem Artikel werden eine Vielzahl von Methoden und Tools eingeführt, um PostgreSQL -Datenbanken im Debian -System zu überwachen, um die Datenbankleistung vollständig zu erfassen. 1. verwenden Sie PostgreSQL, um die Überwachungsansicht zu erstellen. PostgreSQL selbst bietet mehrere Ansichten für die Überwachung von Datenbankaktivitäten: PG_STAT_ACTIVITY: Zeigt Datenbankaktivitäten in Echtzeit an, einschließlich Verbindungen, Abfragen, Transaktionen und anderen Informationen. PG_STAT_REPLIKATION: Monitore Replikationsstatus, insbesondere für Stream -Replikationscluster. PG_STAT_DATABASE: Bietet Datenbankstatistiken wie Datenbankgröße, Transaktionsausschüsse/Rollback -Zeiten und andere Schlüsselindikatoren. 2. Verwenden Sie das Log -Analyse -Tool PGBADG

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Wie kann man im Beegoorm -Framework die mit dem Modell zugeordnete Datenbank angeben? In vielen BeEGO -Projekten müssen mehrere Datenbanken gleichzeitig betrieben werden. Bei Verwendung von BeEGO ...
