golang Type Assertion: Handling Datenbank Typ Conversions
In GO geben Sie die Behauptungen an, einen Wert auf einen anderen Typ zu konvertieren, basierend auf seinem tatsächlichen Typ. Dies ist nützlich, wenn Sie mit dynamischen Typen arbeiten oder benutzerdefinierte Schnittstellen implementieren.
Betrachten Sie ein Szenario, in dem wir einen benutzerdefinierten Typ namens Rolle basierend auf einer Zeichenfolge erstellen und es mit einem Datenbank -Treiber verwenden möchten. Dazu müssen wir die Schnittstellen und Scanner -Schnittstellen implementieren.
Bei der Implementierung dieser Schnittstellen können wir jedoch auf den Fehler stoßen:
cannot convert value.(string) (type string) to type *Role
func (r *rollen) scan (value interface {}) Fehler { *r = Rolle (Wert. (String)) Null zurückkehren }
Lösung für Wertfunktion:
func (r *Role) Scan(value interface{}) error { *r = Role(value.(string)) return nil }
func (r rollen) value () (Driver.Value, Fehler) { Return String (R), Nil } Beachten Sie, dass diese Funktion Nullwerte nicht behandelt oder produziert.
Wenn wir diesen Korrekturen folgen, können wir bei der Arbeit mit Datenbank -Treibern erfolgreich die Typkonvertierung für unseren benutzerdefinierten Rollentyp implementieren.
.Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3