Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Mengendalikan Nilai Masa Nullable dalam Struktur Pangkalan Data Go?

Bagaimana untuk Mengendalikan Nilai Masa Nullable dalam Struktur Pangkalan Data Go?

Patricia Arquette
Patricia Arquetteasal
2024-12-10 14:40:14713semak imbas

How to Handle Nullable Time Values in Go Database Structs?

Mengendalikan Nilai Masa Nullable

Apabila bekerja dengan lajur pangkalan data boleh null dalam Go, anda mungkin menghadapi cabaran untuk mewakilinya dalam struct anda. Pertimbangkan struct seperti berikut:

type Reminder struct {
    Id         int
    CreatedAt  time.Time
    RemindedAt *time.Time
    SenderId   int
    ReceiverId int
}

Di sini, medan RemindedAt ditandakan sebagai penunjuk untuk menampung nilai nullable. Walau bagaimanapun, ini memperkenalkan keperluan untuk membezakan antara CreatedAt dan RemindedAt dalam kod anda.

Penyelesaian yang lebih elegan ialah menggunakan jenis khusus yang mengendalikan nilai nullable. Pustaka pq menyediakan pq.NullTime untuk tujuan ini, dan perpustakaan standard dalam Go 1.13 memperkenalkan sql.NullTime.

Menggunakan pq.NullTime, anda boleh mentakrifkan struct anda sebagai:

import (
    "time"

    "github.com/lib/pq"
)

type Reminder struct {
    Id         int
    CreatedAt  time.Time
    RemindedAt pq.NullTime
    SenderId   int
    ReceiverId int
}

Ini membolehkan anda bekerja dengan lancar dengan nilai yang boleh dibatalkan tanpa memerlukan pengendalian penunjuk yang jelas. Jenis pq.NullTime melaksanakan antara muka Pengimbas dan Penilai, membolehkannya digunakan dengan operasi pangkalan data.

Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Nilai Masa Nullable dalam Struktur Pangkalan Data Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn