Strukturfeldbenennung beim GORM-Abfragescannen
Wenn Sie versuchen, die Ergebnisse einer Abfrage in eine benutzerdefinierte GORM-Struktur zu scannen, ist dies unbedingt zu beachten die Konvention, die GORM für die Feldbenennung anwendet. Standardmäßig erwartet GORM, dass die Strukturfelder mit den Spaltennamen im Abfrageergebnis übereinstimmen.
Um das Problem mit den Standardwerten zu beheben, versuchen Sie die folgenden Ansätze:
Option 1: Öffentliche Felder und richtige Benennung
<code class="go">type Res struct { ID int Number int UserID int }</code>
Option 2: Benutzerdefinierte Spaltenzuordnungen
Alternativ können Sie explizite Spaltenzuordnungen mithilfe des gorm:"column"-Tags angeben jedes Feld. Dadurch können Sie einen anderen Namen für das Feld definieren und gleichzeitig den ursprünglichen Spaltennamen im Abfrageergebnis beibehalten. Zum Beispiel:
<code class="go">type res struct { id int `gorm:"column:id"` number int `gorm:"column:number"` user_id int `gorm:"column:user_id"` }</code>
Durch die Implementierung einer dieser Optionen sollten Sie in der Lage sein, die Abfrageergebnisse erfolgreich in Ihre benutzerdefinierte GORM-Struktur zu scannen.
Das obige ist der detaillierte Inhalt vonWie werden GORM-Strukturfelder mit Abfragespaltennamen abgeglichen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!