登录
首页 >  Golang >  Go问答

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

来源:stackoverflow

时间:2024-03-31 23:45:24 171浏览 收藏

本篇文章给大家分享《如何使查询结果结构与我在 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 上声明的结构相匹配》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>