Heim > Backend-Entwicklung > Golang > Wie initialisiere ich ein sql.NullString-Feld in GORM?

Wie initialisiere ich ein sql.NullString-Feld in GORM?

Susan Sarandon
Freigeben: 2024-11-05 15:59:02
Original
907 Leute haben es durchsucht

How to Initialize a sql.NullString Field in GORM?

Typ String kann nicht als SQL.NullString verwendet werden

Problem

Beim Erstellen eines GORM-Modells mit einem Feld vom Typ sql.NullString, ein Versuch Das Initialisieren des Felds mit einem Zeichenfolgenwert führt zu folgendem Fehler:

cannot use "a string goes here", (type string) as type sql.NullString in field value
Nach dem Login kopieren

Lösung

Der Typ sql.NullString ist eigentlich kein Zeichenfolgentyp, sondern eine Struktur, die eine Zeichenfolge und einen booleschen Wert kapselt Flag, das angibt, ob die Zeichenfolge gültig ist (nicht NULL). Um ein sql.NullString-Feld zu initialisieren, muss es mit einem Strukturwert und nicht mit einem Zeichenfolgenwert initialisiert werden.

Der folgende Code zeigt, wie ein sql.NullString-Feld korrekt initialisiert wird:

<code class="go">db.Create(&Day{
  Nameday:     "Monday",
  Dateday:     "23-10-2019",
  Something:   sql.NullString{String: "a string goes here", Valid: true},
  Holyday:     false,
})</code>
Nach dem Login kopieren

Alternative

Alternativ kann ein benutzerdefinierter nullfähiger Zeichenfolgentyp definiert werden, der die Schnittstellen sql.Scanner und drivers.Valuer implementiert und ein Nullbyte verwendet, um einen NULL-Wert zu signalisieren. Mit diesem benutzerdefinierten Typ kann die ursprüngliche Syntax verwendet werden, um ein nullfähiges Zeichenfolgenfeld zu initialisieren.

Benutzerdefinierter Typ:

<code class="go">type MyString string

const MyStringNull MyString = "\x00"

// implements driver.Valuer, will be invoked automatically when written to the db
func (s MyString) Value() (driver.Value, error) {
  if s == MyStringNull {
    return nil, nil
  }
  return []byte(s), nil
}

// implements sql.Scanner, will be invoked automatically when read from the db
func (s *MyString) Scan(src interface{}) error {
  switch v := src.(type) {
  case string:
    *s = MyString(v)
  case []byte:
    *s = MyString(v)
  case nil:
    *s = MyStringNull
  }
  return nil
}</code>
Nach dem Login kopieren

Verwendung:

<code class="go">db.Create(&Day{
  Nameday:     "Monday",
  Dateday:     "23-10-2019",
  // no need for explicit typing/conversion
  Something:   "a string goes here",
  Holyday:     false,
})</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie initialisiere ich ein sql.NullString-Feld in GORM?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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