GO:导入一个结构并在 json 中重命名它
php小编鱼仔为您介绍一种在JSON中导入一个结构并重命名它的方法,即使用"GO"关键字。在JSON中,我们经常需要使用已定义的结构,但有时候我们需要将其重命名以适应特定的需求。使用"GO"关键字,我们可以在导入结构的同时,对其进行重命名操作,从而更好地满足我们的需求。这种方法简单易用,让我们能够更加灵活地处理JSON数据。接下来,让我们一起来了解一下具体的操作步骤吧!
问题内容
我用 gorm 建立了一个数据库。为此,我创建了一个结构,并使用该结构创建了一个表。到目前为止,一切都很好。在后端,一切正常,但在前端,问题是调用的 json 总是返回大写的 id,而 swagger 会生成一个小写的 id。 go 中有没有一种方法可以使用 json 标识符覆盖从 gorm 导入的结构?
import "gorm.io/gorm"
type report struct {
gorm.model
createdby user `gorm:"foreignkey:createdbyuserid" json:"createdby"`
archived bool `json:"archived"`
}
这个结构给了我以下响应
{
"ID": 8,
"CreatedAt": "2022-11-15T20:45:16.83+01:00",
"UpdatedAt": "2022-12-27T21:34:17.871+01:00",
"DeletedAt": null
"createdBy": {
"ID": 1,
"CreatedAt": "2022-11-15T20:02:17.497+01:00",
"UpdatedAt": "2022-11-15T20:02:17.497+01:00",
...
},
"archived": true,
}
有没有办法使 id 小写(如 archived
)?或者我可以在 swaggo 调整它,使其以大写形式生成。
我所看到的是,您可以在没有此 gorm.model
的情况下制作表格并自己定义所有属性。问题是我必须自己创建这些列的所有功能(删除、更新、索引、主键……)。
解决方法
我创建自己的 gorm-model-struct:
type gormmodel struct {
id uint `gorm:"primarykey" json:"id"`
createdat time.time `json:"createdat"`
updatedat time.time `json:"updatedat"`
deletedat gorm.deletedat `gorm:"index" json:"deletedat"`
} //@name models.gormmodel
我将此结构导入到其他结构中:
type Report struct {
GormModel
CreatedBy User `gorm:"foreignKey:CreatedByUserID" json:"createdBy"`
Archived bool `json:"archived"`
}
重要的是,您添加 json-key 并设置属性名称。
以上就是GO:导入一个结构并在 json 中重命名它的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341