变蓝 mysql "unsupported type []string, a slice of string"
Go-gorm mysql "unsupported type []string, a slice of string"
我使用 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 type: unsupported type []string, a slice of string)
。我知道 mysql 不支持这种类型,但我能以某种方式解决这个问题吗?我想我可以将类型更改为 json.rawMessage
,但我认为这是错误的方式。
我用方言"github.com/jinzhu/gorm/dialects/mysql"
如果您想要 MySql 中的内容列表,您有两个选择
- 您可以自己序列化列表(以逗号分隔的字符串,json,或其他序列化格式)并将其存储在字符串或字节列中。
- 可以使用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)
您可以使用 datatypes.JSON
作为您的类型
import "gorm.io/datatypes"
type Game struct {
Images datatypes.JSON `json:"images"`
}
我使用 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 type: unsupported type []string, a slice of string)
。我知道 mysql 不支持这种类型,但我能以某种方式解决这个问题吗?我想我可以将类型更改为 json.rawMessage
,但我认为这是错误的方式。
我用方言"github.com/jinzhu/gorm/dialects/mysql"
如果您想要 MySql 中的内容列表,您有两个选择
- 您可以自己序列化列表(以逗号分隔的字符串,json,或其他序列化格式)并将其存储在字符串或字节列中。
- 可以使用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)
您可以使用 datatypes.JSON
作为您的类型
import "gorm.io/datatypes"
type Game struct {
Images datatypes.JSON `json:"images"`
}