登录
首页 >  Golang >  Go问答

额外列中的自引用模型

来源:stackoverflow

时间:2024-03-05 16:33:37 107浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《额外列中的自引用模型》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

我刚刚开始使用 gorm,在定义模型时遇到了麻烦。

我按照自引用模型的文档示例成功创建了一个连接表:

type User struct {
  gorm.Model
  Friends []*User `gorm:"many2many:friendships;association_jointable_foreignkey:friend_id"`
}

问题是我想在连接表中添加一个额外的列来了解好友是否被接受。我通过互联网寻找答案,但我找到的唯一答案是: https://github.com/jinzhu/gorm/issues/719#issuecomment-168485989 但我不明白如何在我的情况下调整它。

如果有人有任何例子和/或解决方案,我将不胜感激。 再次感谢!


解决方案


这个答案晚了 4 年,但我今天遇到了同样的问题,所以希望这对任何人都有帮助。

要向 gorm 中自引用多对多关系创建的联接表添加额外列,您需要创建一个自定义联接表。在这篇文章的例子中,模型将如下所示:

type user struct {
    gorm.model
    friends []*user `gorm:"many2many:friends"`
}

// custom join table
type friend struct {
    userid   int `gorm:"primary_key"`
    friendid int `gorm:"primary_key"`
    accepted bool
}

然后,您使用 setupjointable 方法before 使用 automigrate 方法。直到我在 migrate 方法之前调用 join 方法之前,这对我不起作用:

err := db.SetupJoinTable(&User{}, "Friends", &Friendship{})
err = db.AutoMigrate(&User{})

这应该创建带有额外列的连接表。

希望这有帮助!

理论要掌握,实操不能落!以上关于《额外列中的自引用模型》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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