


Bagaimana untuk Mengendalikan Nilai Masa Nullable dalam Struktur Pangkalan Data Go?
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

GO Language Pack Import: Apakah perbezaan antara garis bawah dan tanpa garis bawah?

Bagaimana untuk melaksanakan pemindahan maklumat jangka pendek antara halaman dalam kerangka beego?

Bagaimana cara menukar senarai hasil pertanyaan mysql ke dalam slice struktur tersuai dalam bahasa Go?

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO?

Bagaimana saya menulis objek dan stub untuk ujian di GO?

Bagaimana anda menulis ujian unit di GO?

Bagaimana cara menulis fail dalam bahasa Go dengan mudah?

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya?
