Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mengendalikan Medan Rentetan Nullable dengan GORM dan sql.NullString?

Bagaimana untuk Mengendalikan Medan Rentetan Nullable dengan GORM dan sql.NullString?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-06 03:29:02629semak imbas

How to Handle Nullable String Fields with GORM and sql.NullString?

Tidak Dapat Menggunakan Type String sebagai sql.NullString

Query

Dalam GORM, menggunakan sql.NullString untuk medan yang mungkin NULL menghadap ke ralat:

cannot use "a string goes here", (type string) as type sql.NullString in field value

semasa cuba melaksanakan contoh pengesahan GORM yang mudah.

Resolusi

sql.NullString bukan jenis rentetan tetapi jenis struct yang ditakrifkan sebagai:

type NullString struct {
    String string
    Valid  bool // Valid is true if String is not NULL
}

Untuk memulakannya dengan betul, gunakan sintaks berikut:

db.Create(&Day{
    Nameday:     "Monday",
    Dateday:     "23-10-2019",
    Something:   sql.NullString{String: "a string goes here", Valid: true},
    Holyday:     false,
})

Penyelesaian Alternatif

Sebagai alternatif, untuk mengekalkan sintaks permulaan yang lebih mudah:

  1. Tentukan jenis rentetan nullable tersuai:

    type MyString string
  2. Laksanakan antara muka sql.Scanner dan driver.Valuer untuk mengendalikan penukaran nilai.
  3. Timpa kaedah Value() dan Scan() seperti berikut:

    func (s MyString) Value() (driver.Value, error) {
        if s == MyStringNull {
            return nil, nil
        }
        return []byte(s), nil
    }
    
    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
    }
  4. Isytiharkan medan Sesuatu sebagai MyString dan mulakannya seperti yang dimaksudkan:

    db.Create(&Day{
        Nameday:     "Monday",
        Dateday:     "23-10-2019",
        // Here, an untyped string constant will explicitly convert to MyString because they have the same underlying type.
        Something:   "a string goes here",
        Holyday:     false,
    })

Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Medan Rentetan Nullable dengan GORM dan sql.NullString?. 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