第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

Gorm NOT NULL 約束 STILL PASSES FOR NULL

Gorm NOT NULL 約束 STILL PASSES FOR NULL

Go
慕斯709654 2023-02-14 18:29:00
在我的結(jié)構(gòu)中,我有以下內(nèi)容type Task struct {    gorm.Model    Id         int       `json:"id" gorm:"primaryKey;AUTO_INCREMENT"`    UserId int       `json:"user_id" gorm:"Index;not null" validate:"required"`    TaskId     int       `json:"task_id" gorm:"Index;not null" validate:"required"`    JobId      int       `json:"job_id" gorm:"not null" validate:"required"`    Latitude   float64   `json:"latitude" gorm:"not null" validate:"required"`    Longitude  float64   `json:"longitude" gorm:"not null" validate:"required"`    StartAt    time.Time `json:"start_at"`    EndAt      time.Time `json:"end_at"`    CreatedAt  time.Time    UpdatedAt  time.Time}我有這個(gè)功能可以用以下內(nèi)容保存到表中{   "user_id": 1,    "location":[5748.5445, 89790.454],    "latitude": 89790.454,    "longitude": 5748.5445,    "startAt":  "2030-10-30T10:58:00.000Z",    "endAt": "2031-10-30T10:58:00.000Z"}func CreateTask(c *fiber.Ctx) error {    var opentask models.JobOpenTask        if err := c.BodyParser(&opentask); err != nil {        return c.Status(400).JSON(err.Error())    }        db.DB.Db.Create(&opentask)    return c.Status(200).JSON("OK")}當(dāng)它運(yùn)行時(shí),它仍然將記錄保存在 DB 上,但我希望它在嘗試保存時(shí)會(huì)拋出錯(cuò)誤,因?yàn)樗趎ot null我的結(jié)構(gòu)中,但為什么它能夠保存到 Db 而不會(huì)拋出錯(cuò)誤?
查看完整描述

3 回答

?
胡子哥哥

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超6個(gè)贊

  • 首先,您應(yīng)該檢查遷移是否已正確運(yùn)行,這意味著在數(shù)據(jù)庫(kù)中創(chuàng)建了列not null約束。user_id, task_id, job_id, ..

  • 其次,您必須使用指針,因?yàn)?code>golang有一個(gè)概念zero value意味著intfloatstring,如果您沒(méi)有分配任何值,則相應(yīng)地具有bool默認(rèn)值, , 。但是如果你使用指針那么這個(gè)字段將最終將在數(shù)據(jù)庫(kù)中發(fā)送。如果對(duì)該列有約束,則會(huì)發(fā)生錯(cuò)誤。00.0""falsenilNULLNOT NULL


查看完整回答
反對(duì) 回復(fù) 2023-02-14
?
九州編程

TA貢獻(xiàn)1785條經(jīng)驗(yàn) 獲得超4個(gè)贊

您需要為此使用sql.NullIntxxnot null或 int/float 指針,因?yàn)?int/float 的默認(rèn)/空值為 0,這是針對(duì)數(shù)據(jù)庫(kù)的。

所以 gorm 和 DB 將允許它作為非空值傳遞。

類似地,對(duì)于string必須使用*stringsql.NullStting作為默認(rèn)值的類型string是“”(空白字符串)而不是零。


查看完整回答
反對(duì) 回復(fù) 2023-02-14
?
慕桂英4014372

TA貢獻(xiàn)1871條經(jīng)驗(yàn) 獲得超13個(gè)贊

null 只申請(qǐng)指針

gorm.Model包括

type Model struct {

    ID        uint `gorm:"primarykey"`

    CreatedAt time.Time

    UpdatedAt time.Time

    DeletedAt DeletedAt `gorm:"index"`

}

你不需要Id, CreatedAt, UpdatedAt在你的結(jié)構(gòu)中聲明


如下更正您的結(jié)構(gòu):

type Task struct {

    gorm.Model

    UserId     int       `json:"user_id"`

    TaskId     int       `json:"task_id"`

    JobId      int       `json:"job_id"`

    Latitude   float64   `json:"latitude"`

    Longitude  float64   `json:"longitude"`

    StartAt    time.Time `json:"start_at"`

    EndAt      time.Time `json:"end_at"`

}

標(biāo)簽和最佳實(shí)踐是由數(shù)據(jù)庫(kù)控制的,列定義為非空約束


AUTO_INCREMENT 應(yīng)該在創(chuàng)建表時(shí)在數(shù)據(jù)庫(kù)上創(chuàng)建,這需要由數(shù)據(jù)庫(kù)控制,而不是由語(yǔ)言控制


聲明表如下:


create table tasks (

   int primary key AUTO_INCREMENT,

   user_id int not null, 

   task_id int not null,

   job_id int not null,

   latitude int not null,

   longitude int not null,

   start_at datetime,

   created_at datetime,

   updated_at datetime

)

祝你學(xué)習(xí)順利!



查看完整回答
反對(duì) 回復(fù) 2023-02-14
  • 3 回答
  • 0 關(guān)注
  • 457 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)