Heim > Backend-Entwicklung > Golang > Wie führe ich die Verknüpfung mehrerer Tabellen in GORM durch?

Wie führe ich die Verknüpfung mehrerer Tabellen in GORM durch?

Mary-Kate Olsen
Freigeben: 2024-10-24 14:42:02
Original
603 Leute haben es durchsucht

How to Perform Multiple Table Joining in GORM?

Mehrere Tabellenverknüpfung in GORM

Die Verknüpfung mehrerer Tabellen in GORM beinhaltet die Herstellung von Beziehungen zwischen Modellen, die verschiedene Tabellen in der Datenbank darstellen. Die GORM-Syntax für Mehrfachtabellen-Joins nutzt die Joins()-Methode, um die Join-Kriterien anzugeben.

Beispiel:

Betrachten Sie das folgende Beispiel, in dem wir drei Tabellen haben:

  • Abteilung (gorm.Modal, dep_name)
  • Mitarbeiter (gorm.Modal, emp_id, emp_name, Department_id)
  • EmployeeContact (gorm.Modal, Employee_id, emp_contact_no)

Die folgende Abfrage ruft Daten aus allen drei Tabellen basierend auf den angegebenen Join-Bedingungen ab:

SELECT * FROM department d, employee e, employeeContact ec WHERE d.id = e.department_id and e.id = ec.employee_id
Nach dem Login kopieren

Um diese Abfrage mit GORM durchzuführen, können wir den folgenden Code verwenden:

<code class="go">if err := db.Table("employee").Select("department.id, employee.department_id, employeeContact.employee_id").Joins("JOIN department ON department.id = employee.department_id").Joins("JOIN employeeContact ON employeeContact.id = employee.id").Find(&results).Error; err != nil {
    return err, ""
}</code>
Nach dem Login kopieren

In diesem Code:

  • db.Table("employee") gibt die Primärtabelle für die Abfrage an.
  • Select() definiert die zu bearbeitenden Felder wird aus den verbundenen Tabellen abgerufen.
  • Joins() legt die Verknüpfungskriterien für jede Tabelle fest.
  • Find() ruft die Ergebnisse in der Ergebnisvariablen ab.

Das obige ist der detaillierte Inhalt vonWie führe ich die Verknüpfung mehrerer Tabellen in GORM durch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage