繁体   English   中英

sql:列索引 5 上的扫描错误,名称“todos”:不支持扫描,存储驱动程序。值类型 []uint8 到类型 *[]datatypes.JSON golang gorm

[英]sql: Scan error on column index 5, name "todos": unsupported Scan, storing driver.Value type []uint8 into type *[]datatypes.JSON golang gorm

这是 model:

type Board struct {
    Id     uint `gorm:"primaryKey;autoIncrement;unique" json:"id"`
    Owner  uint `json:"owner"`
    Name string `json:"name"`
    Contributors []int `gorm:"type:jsonb" json:"contributors"`
    GeneratedLink string `gorm:"default:''" json:"generated_link"`
    Todos []datatypes.JSON `gorm:"type:jsonb" json:"todos"`
}

type TodoStructure struct {
    Id string `json:"id"`
    Text string `json:"text"`
    Completed bool `json:"completed"`
    Important bool `json:"important"`
}

这就是我创建董事会的方式:

board := models.Board{
    Owner:         20,
    Name:          "text",
    GeneratedLink: "",
    Todos: []datatypes.JSON{datatypes.JSON("[]")},
}

database.DB.Create(&board)

这是创建板后列的外观:图片

所以 todos 只是一个空数组。 这就是我创建待办事项的方式:

func createTodo(c *gin.Context) {
    var board models.board
    database.DB.Where("id = ?", 1).First(&board)
    id := uuid.NewV4().String()
    todoStruct := models.TodoStructure{
        Id:        id,
        Text:      "text",
        Completed: false,
        Important: false,
    }

    jsonData, _ := json.Marshal(todoStruct)
    board.Todos = append(board.Todos, jsonData)
    fmt.Println(board.Todos) //exactly what i need [{"id":"e7ee015ab54c48388aa2413428f76f50","text":"text","completed":false,"important":false}]
    database.DB.Save(&board)
    c.JSON(http.StatusCreated, gin.H{"message": "success"})
}

但我得到了错误:

sql: Scan error on column index 5, name "todos": unsupported Scan, storing driver.Value type []uint8 into type *[]datatypes.JSON

并在列 todo 值保存如下:

图片

图片

只是 json object,但我需要像这样保存:

[{"id":"e7ee015ab54c48388aa2413428f76f50","text":"text","completed":false,"important":false}]

图片

图片

请任何想法,任何选项,我试图在谷歌中找到解决方案,但没有找到正确的解决方案。

PS 使用 gorm 和 postgresql

我认为您使用了不正确的数据类型。 你可以试试这条线吗?

    Todos []byte `gorm:"type:jsonb" json:"todos"`

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM