亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Gorm NOT NULL 約束 STILL PASSES FOR NULL

Gorm NOT NULL 約束 STILL PASSES FOR NULL

Go
慕斯709654 2023-02-14 18:29:00
在我的結構中,我有以下內容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}我有這個功能可以用以下內容保存到表中{   "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")}當它運行時,它仍然將記錄保存在 DB 上,但我希望它在嘗試保存時會拋出錯誤,因為它在not null我的結構中,但為什么它能夠保存到 Db 而不會拋出錯誤?
查看完整描述

3 回答

?
胡子哥哥

TA貢獻1825條經驗 獲得超6個贊

  • 首先,您應該檢查遷移是否已正確運行,這意味著在數據庫中創建了列not null約束。user_id, task_id, job_id, ..

  • 其次,您必須使用指針,因為golang有一個概念zero value意味著intfloatstring,如果您沒有分配任何值,則相應地具有bool默認值, , 。但是如果你使用指針那么這個字段將最終將在數據庫中發送。如果對該列有約束,則會發生錯誤。00.0""falsenilNULLNOT NULL


查看完整回答
反對 回復 2023-02-14
?
九州編程

TA貢獻1785條經驗 獲得超4個贊

您需要為此使用sql.NullIntxxnot null或 int/float 指針,因為 int/float 的默認/空值為 0,這是針對數據庫的。

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

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


查看完整回答
反對 回復 2023-02-14
?
慕桂英4014372

TA貢獻1871條經驗 獲得超13個贊

null 只申請指針

gorm.Model包括

type Model struct {

    ID        uint `gorm:"primarykey"`

    CreatedAt time.Time

    UpdatedAt time.Time

    DeletedAt DeletedAt `gorm:"index"`

}

你不需要Id, CreatedAt, UpdatedAt在你的結構中聲明


如下更正您的結構:

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"`

}

標簽和最佳實踐是由數據庫控制的,列定義為非空約束


AUTO_INCREMENT 應該在創建表時在數據庫上創建,這需要由數據庫控制,而不是由語言控制


聲明表如下:


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

)

祝你學習順利!



查看完整回答
反對 回復 2023-02-14
  • 3 回答
  • 0 關注
  • 427 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號