Heim > Artikel > Backend-Entwicklung > Wie bette ich eine Struktur in eine andere Struktur in GORM ein und speichere sie als Feld in der Haupttabelle?
Strukturen mit GORM einbetten
Wenn in GORM eine Struktur in eine andere eingebettet wird, erstellt GORM möglicherweise eine separate Tabelle für die eingebettete Struktur. Wenn Sie die eingebettete Struktur jedoch als zusätzliches Feld innerhalb der Haupttabelle speichern möchten, kann der folgende Ansatz verwendet werden:
Lösung:
<code class="go">type A struct { Point *GeoPoint } type GeoPoint struct { Lat float64 Lon float64 }</code>
<code class="go">func (gp *GeoPoint) Scan(src interface{}) error { // Convert the `src` value to a byte array. b, ok := src.([]byte) if !ok { return fmt.Errorf("could not convert to byte array") } // Unmarshal the byte array into the `GeoPoint` struct. if err := json.Unmarshal(b, gp); err != nil { return fmt.Errorf("could not unmarshal JSON: %v", err) } return nil } func (gp GeoPoint) Value() (driver.Value, error) { // Marshal the `GeoPoint` struct into a byte array. b, err := json.Marshal(gp) if err != nil { return nil, fmt.Errorf("could not marshal JSON: %v", err) } return string(b), nil }</code>
<code class="go">type A struct { gorm.Model Point *GeoPoint `gorm:"column:point;type:json"` }</code>
Durch die Implementierung der Scan- und Value-Methoden kann GORM die eingebettete Struktur in und aus einem JSON-Format konvertieren. Die Tags gorm:"column" und gorm:"type" geben den Spaltennamen und den Datentyp für die eingebettete Struktur in der Haupttabelle an.
Das obige ist der detaillierte Inhalt vonWie bette ich eine Struktur in eine andere Struktur in GORM ein und speichere sie als Feld in der Haupttabelle?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!