我使用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"
答案 0 :(得分:2)
如果要在MySql中列出某些内容,则有两个选择
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)