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 }
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 }
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 }
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!