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!