返回顶部
首页 > 资讯 > 后端开发 > GO >如何使查询结果结构与我在 GORM Select 上声明的结构相匹配
  • 392
分享到

如何使查询结果结构与我在 GORM Select 上声明的结构相匹配

2024-04-05 00:04:14 392人浏览 安东尼
摘要

本篇文章给大家分享《如何使查询结果结构与我在 GORM Select 上声明的结构相匹配》,覆盖了golang的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读

本篇文章给大家分享《如何使查询结果结构与我在 GORM Select 上声明的结构相匹配》,覆盖了golang的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

问题内容

我想让查询结果的结构与我在 Gorm select 中所说的相匹配,因为现在它只匹配 struct 结构。我该如何让它发挥作用?预先感谢您

我尝试创建新的结构并且它有效,但我不知道这是否是最佳实践

type user struct {
    user_id  uint   `JSON:"user_id" gorm:"column:user_id; primary_key"`
    email    string `json:"email"`
    passWord string `json:"password"`
    token    string `json:"token" gorm:"-"`
}

func getusers() map[string]interface{} {
    users := []user{}
    getdb().table("app_user").select("user_id, email").find(&users)
    resp := u.message(true, "all users")
    resp["users"] = users
    return resp
}
//actual result
{
    "message": "All users",
    "status": true,
    "users": [
        {
            "user_id": 1732,
            "email": "[email protected]",
            "password": "",
            "token": ""
        },
        {
            "user_id": 1733,
            "email": "[email protected]",
            "password": "",
            "token": ""
        },
    ]
}

//Expected result 
{
    "message": "All users",
    "status": true,
    "users": [
        {
            "user_id": 1732,
            "email": "[email protected]"
        },
        {
            "user_id": 1733,
            "email": "[email protected]"
        }
     ]
}


解决方案


看起来您所需要做的就是省略空字段。您可以通过向 json 标签添加 omitempty 来做到这一点:

Password string `json:"password,omitempty"`
    Token    string `json:"token,omitempty" gorm:"-"`

今天关于《如何使查询结果结构与我在 GORM Select 上声明的结构相匹配》的内容介绍就到此结束,如果有什么疑问或者建议,可以在编程网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

您可能感兴趣的文档:

--结束END--

本文标题: 如何使查询结果结构与我在 GORM Select 上声明的结构相匹配

本文链接: https://lsjlt.com/news/596318.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作