首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >One2Many关系没有ID的基模型

One2Many关系没有ID的基模型
EN

Stack Overflow用户
提问于 2022-09-27 15:20:21
回答 1查看 33关注 0票数 1

我们目前有以下模式;

代码语言:javascript
复制
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: relation=\"Reactions\" does not have base model=Post with id=\"\" (check join conditions)

代码语言:javascript
复制
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都是null),但是我们检索的列比我们想要的多。

EN

回答 1

Stack Overflow用户

发布于 2022-09-27 16:16:45

我不是一个专业的,但这不是反应在邮政模式。它应该是Reactions Reaction ...而不是Reactions Reactions ...。因为模型是反应而不是反应。我希望它能解决这个问题,我不是个傻瓜。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73870024

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档