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

Bagaimana untuk Mengendalikan Rentetan Nullable dalam Model GORM?

Patricia Arquette
Patricia Arquetteasal
2024-11-06 01:28:02893semak imbas

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>

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>

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>

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!

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