Maison > développement back-end > Golang > Comment gérer au mieux les valeurs temporelles nullables dans les structures Go ?

Comment gérer au mieux les valeurs temporelles nullables dans les structures Go ?

Susan Sarandon
Libérer: 2024-12-31 12:11:12
original
396 Les gens l'ont consulté

How to Best Handle Nullable Time Values in Go Structs?

Gestion des valeurs temporelles nullables avec des structures dans Go

Lorsque vous travaillez avec des structures de données pouvant contenir des valeurs temporelles nullables, il est important d'assurer une gestion appropriée de ces valeurs. Considérez la structure suivante :

type Reminder struct {
    Id         int
    CreatedAt  time.Time
    RemindedAt *time.Time
    SenderId   int
    ReceiverId int
}
Copier après la connexion

Ici, le champ RappelAt est déclaré comme un pointeur vers un time.Time, car il est possible qu'il soit nul. Cependant, cette distinction nécessite que le code gère la différence entre CreatedAt et RemendedAt.

Pour résoudre ce problème, Go propose plusieurs approches pour gérer avec élégance les valeurs de temps nullables :

Utilisation de pq.NullTime

Le package pq du pilote PostgreSQL Go propose le type pq.NullTime. Il se compose d'une valeur time.Time et d'un indicateur booléen Valid indiquant si l'heure est valide (et non NULL).

import "github.com/lib/pq"

type Reminder struct {
    Id         int
    CreatedAt  time.Time
    RemindedAt pq.NullTime
    SenderId   int
    ReceiverId int
}
Copier après la connexion

Dans ce cas, RemendedAt est une valeur pq.NullTime, et le code peut vérifier son indicateur valide pour déterminer si l'heure est définie.

Utilisation de sql.NullTime (Go 1.13 et ci-dessus)

À partir de Go 1.13, la bibliothèque standard introduit le type sql.NullTime, qui sert un objectif similaire à pq.NullTime.

import "database/sql"

type Reminder struct {
    Id         int
    CreatedAt  time.Time
    RemindedAt sql.NullTime
    SenderId   int
    ReceiverId int
}
Copier après la connexion

Pq.NullTime et sql.NullTime implémente les interfaces nécessaires pour prendre en charge l'analyse de la base de données et la liaison des paramètres, ce qui les rend pratiques à utiliser avec les opérations de base de données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal