Go-gorm mysql“不受支持的类型[] string,字符串的一部分”

时间:2018-09-09 11:22:38

标签: 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"

1 个答案:

答案 0 :(得分:2)

如果要在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)