GORM 逗号分隔值字段
GORM comma separated values field
首先,我知道这是不好的做法,无论如何我都可以在客户端进行拆分,但我想知道如何在后端实现它。
我有这个结构
type Article struct{
ArticleId int `gorm:"column:article_id;primaryKey" json:"article_id"`
Title string `gorm:"column:title" json:"title"`
Content string `gorm:"column:content" json:"content"`
Tags string `gorm:"column:tags" json:"tags"`
}
对于标签,我使用逗号分隔值,例如tech,woman,mit
我可以实现一个简单的函数来手动拆分字符串
func splitTags(values string) []string {
array := strings.Split(values, ",")
return array
}
但是我如何在我的结构中将其实现为自定义类型,以便它自动拆分标签,并且最好在我设置标签值时加入 [] 字符串值?
P.S。上面的结构只是一个例子。
根据评论和此 link,一种选择是创建自定义 Tags
类型。
type Tags []string
//Implement Scanner interface
func (t *Tags) Scan(value interface{}) error {
val, ok := value.([]byte)
if !ok {
return errors.New(fmt.Sprint("wrong type", value))
}
*t = Tags(strings.Split(string(val), ","))
return nil
}
//Implement Valuer interface
func (t Tags) Value() (driver.Value, error) {
//this check is here if you don't want to save an empty string
if len(t) == 0 {
return nil, nil
}
return []byte(strings.Join(t, ",")), nil
}
首先,我知道这是不好的做法,无论如何我都可以在客户端进行拆分,但我想知道如何在后端实现它。
我有这个结构
type Article struct{
ArticleId int `gorm:"column:article_id;primaryKey" json:"article_id"`
Title string `gorm:"column:title" json:"title"`
Content string `gorm:"column:content" json:"content"`
Tags string `gorm:"column:tags" json:"tags"`
}
对于标签,我使用逗号分隔值,例如tech,woman,mit
我可以实现一个简单的函数来手动拆分字符串
func splitTags(values string) []string {
array := strings.Split(values, ",")
return array
}
但是我如何在我的结构中将其实现为自定义类型,以便它自动拆分标签,并且最好在我设置标签值时加入 [] 字符串值?
P.S。上面的结构只是一个例子。
根据评论和此 link,一种选择是创建自定义 Tags
类型。
type Tags []string
//Implement Scanner interface
func (t *Tags) Scan(value interface{}) error {
val, ok := value.([]byte)
if !ok {
return errors.New(fmt.Sprint("wrong type", value))
}
*t = Tags(strings.Split(string(val), ","))
return nil
}
//Implement Valuer interface
func (t Tags) Value() (driver.Value, error) {
//this check is here if you don't want to save an empty string
if len(t) == 0 {
return nil, nil
}
return []byte(strings.Join(t, ",")), nil
}