首页  >  文章  >  后端开发  >  GO:导入一个结构并在 json 中重命名它

GO:导入一个结构并在 json 中重命名它

王林
王林转载
2024-02-09 10:36:18543浏览

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 中重命名它的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除