Heim >Backend-Entwicklung >Golang >Wie lege ich Standarddatumswerte für Time.Time-Felder in MGO-Dokumenten fest?

Wie lege ich Standarddatumswerte für Time.Time-Felder in MGO-Dokumenten fest?

Linda Hamilton
Linda HamiltonOriginal
2024-11-23 02:45:29730Durchsuche

How to Set Default Date Values for Time.Time Fields in Mgo Documents?

Standarddatumseinfügung für Mgo-Dokumente mit Time.Time-Feld

Einführung

In MongoDB ist es möglich, Standardwerte für Dokumentfelder festzulegen. Dies kann nützlich sein, um Felder während der Dokumenterstellung automatisch mit bestimmten Werten zu füllen, beispielsweise ein Zeitstempelfeld.

Problem

In Mgo, dem Go-Treiber für MongoDB, gibt es keine direkte Möglichkeit zur Definition Standardwerte für Felder wie im Mongoose-JavaScript-Modell. Entwickler suchen nach einer Lösung, um bei der Erstellung automatisch einen Datums- oder Zeitwert in das Feld eines Dokuments einzufügen.

Lösung

Es gibt zwei Hauptansätze zum Festlegen von Standarddatumswerten in Mgo:

  1. Konstruktorfunktion:

    • Erstellen eine konstruktorähnliche Funktion, die den gewünschten Feldwert festlegt, z. B. CreatedAt.
    • Verwenden Sie diese Funktion immer, um neue Dokumentinstanzen zu erstellen.
    • Dieser Ansatz bietet Kontrolle darüber, wann der Standardwert festgelegt wird. aber es erfordert einen manuellen Eingriff.
  2. Benutzerdefiniert Marshalling:

    • Implementieren Sie die bson.Getter-Schnittstelle in der benutzerdefinierten Struktur, um einen Wert bereitzustellen, bevor dieser tatsächlich gespeichert wird.
    • Verwenden Sie GetBSON(), um eine Kopie davon zurückzugeben struct mit dem gewünschten Feldwertsatz (sofern er nicht bereits festgelegt ist).
    • Dieser Ansatz erfolgt eher automatisch, erfordert jedoch sorgfältige Überlegungen, um einen möglichen Stapel zu vermeiden Überläufe oder unbeabsichtigtes Überschreiben vorhandener Werte.

Implementierungsbeispiel

Für den benutzerdefinierten Marshalling-Ansatz finden Sie hier eine Beispielimplementierung:

import (
    "context"
    "time"

    "github.com/globalsign/mgo/bson"
)

type User struct {
    CreatedAt time.Time `json:"created_at" bson:"created_at"`
}

func (u *User) GetBSON() (interface{}, error) {
    if u.CreatedAt.IsZero() {
        u.CreatedAt = time.Now()
    }
    type my *User
    return my(u), nil
}

func main() {
    session, err := mgo.Dial("localhost:27017")
    if err != nil {
        panic(err)
    }
    defer session.Close()

    c := session.DB("mydb").C("users")

    // Create a new user with a default CreatedAt timestamp
    user := User{}
    err = c.Insert(user)
    if err != nil {
        panic(err)
    }
}

Wenn in diesem Beispiel ein neues Benutzerdokument in die Datenbank eingefügt wird, wird das Feld „CreatedAt“ automatisch auf die aktuelle Zeit gesetzt. Dies wird erreicht, indem die GetBSON()-Methode überschrieben wird, um einen geänderten Strukturwert bereitzustellen, wenn der Datenbanktreiber versucht, das Objekt zum Einfügen zu serialisieren.

Das obige ist der detaillierte Inhalt vonWie lege ich Standarddatumswerte für Time.Time-Felder in MGO-Dokumenten fest?. 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