mysql - go-gorm mysql "unsupported type []string, a slice of string"

标签 mysql go go-gorm

我使用 gorm,并尝试创建到 mysql 的事务。我有一个结构

type Game struct {
    Images []string
}

game := Game{Images: []string{"1.png", "2.png"}}

db := Database()

tx := db.Begin()

if err := tx.Create(&game).Error; err != nil {
    tx.Rollback()
    return errors.New("Cannot add game")
}

tx.Commit()

但是我收到错误 (sql: converting argument $1 type: unsupported type []string, a slice of string)。我知道,mysql 不支持这种类型,但我能以某种方式解决这个问题吗?我想我可以将类型更改为 json.rawMessage,但我认为这是一种错误的方式。

我用方言"github.com/jinzhu/gorm/dialects/mysql"

最佳答案

如果你想要一个 MySql 中的列表,你有两个选择

  1. 您可以自己序列化列表(以逗号分隔的字符串、json 或其他序列化格式)并将其存储在字符串或字节列中。
  2. 您可以使用 join 将两个表关联起来。

gorm 通过它称为关联的东西支持连接。在这种情况下,您有一个有很多关联 ( http://doc.gorm.io/associations.html#has-many )。

您可以如何执行此操作的示例是:

type Game struct {
    gorm.Model
    GameImages   []GameImage
}

type GameImage struct {
    gorm.Model
    Name string
}

db.Model(&game).Related(&gameImages)

关于mysql - go-gorm mysql "unsupported type []string, a slice of string",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52244001/

相关文章:

mysql - mysql数据库迟插入问题

java - 将csv文件导入MySQL数据库时出现无效的utf8字符串

google-app-engine - 静态页面在 Google App Engine 中返回 404

orm - Gorm Golang 获取集合及其关系

go - Go-Gorm有一个始终为空的子表

go - 如何在函数中修改 GORM DB 指针?

backup - MySQL mysqldump.exe 仅备份方案

php - "my network"带有sql子查询的函数

docker - 如何从控制台或Docker容器读取日志

opencv - go 的计算机视觉在我尝试下载它时出现错误