Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk Mengendalikan Rentetan Nullable dalam Model GORM?

Bagaimana untuk Mengendalikan Rentetan Nullable dalam Model GORM?

Patricia Arquette
Lepaskan: 2024-11-06 01:28:02
asal
892 orang telah melayarinya

How to Handle Nullable Strings in GORM Models?

Tidak Dapat Menggunakan Jenis Rentetan sebagai sql.NullString

Apabila mencipta model GORM, anda mungkin menghadapi ralat jika anda cuba menggunakan jenis rentetan untuk medan yang perlu dibatalkan. Isu timbul apabila menggunakan sql.NullString untuk medan nullable.

Masalah:

Ralat yang anda perolehi, "cannot use "a string goes here", ( taip rentetan) sebagai taip sql.NullString dalam nilai medan," menunjukkan bahawa anda cuba untuk menetapkan rentetan terus kepada medan sql.NullString. Walau bagaimanapun, sql.NullString bukan jenis rentetan, tetapi jenis struct yang direka bentuk untuk mewakili rentetan nullable.

Penyelesaian:

Untuk menyelesaikan isu ini, anda perlu memulakan medan sql.NullString dengan betul. Ia harus dimulakan sebagai:

<code class="go">db.Create(&Day{
    Nameday:     "Monday",
    Dateday:     "23-10-2019",
    Something:   sql.NullString{String: "a string goes here", Valid: true},
    Holyday:     false,
})</code>
Salin selepas log masuk

Penyelesaian Alternatif:

Jika anda lebih suka menggunakan sintaks yang dipermudah untuk rentetan nullable, anda boleh mencipta jenis rentetan nullable anda sendiri dengan melaksanakan antara muka sql.Scanner dan driver.Valuer, dan memanfaatkan bait nol untuk menandakan NULL nilai.

<code class="go">type MyString string

const MyStringNull MyString = "\x00"

// implements driver.Valuer, will be invoked automatically when written to the db
func (s MyString) Value() (driver.Value, error) {
    if s == MyStringNull {
        return nil, nil
    }
    return []byte(s), nil
}

// implements sql.Scanner, will be invoked automatically when read from the db
func (s *MyString) Scan(src interface{}) error {
    switch v := src.(type) {
    case string:
        *s = MyString(v)
    case []byte:
        *s = MyString(v)
    case nil:
        *s = MyStringNull
    }
    return nil
}</code>
Salin selepas log masuk

Dengan jenis ini, anda boleh memulakan medan Sesuatu seperti berikut:

<code class="go">db.Create(&Day{
    Nameday:     "Monday",
    Dateday:     "23-10-2019",
    Something:   "a string goes here",
    Holyday:     false,
})</code>
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Rentetan Nullable dalam Model GORM?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan