登录
首页 >  Golang >  Go问答

One2Many 关系没有带 ID 的基本模型

来源:stackoverflow

时间:2024-04-14 09:27:28 329浏览 收藏

本篇文章向大家介绍《One2Many 关系没有带 ID 的基本模型》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

问题内容

我们目前有以下架构;

type reactions []*reaction

type post struct {
    id string `pg:",pk" json:",omitempty"`
    creatorid string `pg:",notnull"`
    creator   *user  `pg:",rel:has-one,fk:creator_id"`
    groups   groups  
    reactions reactions `pg:",rel:has-many" json:",omitempty"`
}

type reaction struct {
    id string `pg:",pk" json:",omitempty"`

    type reactiontype `pg:",notnull"`

    creatorid string `pg:",notnull"`
    creator   *user  `pg:",rel:has-one,fk:creator_id"`

    postid string  `pg:",notnull"`
    post   *post `pg:",rel:has-one,fk:post_id"`
}

当尝试使用以下查询查询所有帖子(包括其反应关系)时,我们收到以下错误消息; pg:关系=\“反应\”没有基本模型=带有id=\“\”的帖子(检查连接条件)

func (pm PGPostRepo) selectQuery(model ...interface{}) *orm.Query {
    return pm.db.Model(model...).
        Relation("Creator.id").
        Relation("Creator.given_name").
        Relation("Creator.family_name").
        Relation("Reactions.type").
        Column("post.*")
        Where("post.id = ?", postID).
        Select()
}

我实际上对这个很迷茫,就好像我们替换 relation("reaction.type")relation("reaction.*") 我们没有收到错误(尽管 creatorpost 都为空),但是我们检索的列比我们想要的多。


正确答案


我不是专业人士,但这不是帖子模型中的反应吗?应该是 Reactions 反应 ... 而不是 Reactions 反应 ...。因为模型是Reaction,而不是Reactions。我希望它能解决问题,我不是个傻子。

好了,本文到此结束,带大家了解了《One2Many 关系没有带 ID 的基本模型》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

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