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
Mary-Kate OlsenOriginal
2024-10-24 14:42:02536Durchsuche

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

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>

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!

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