登录
首页 >  Golang >  Go问答

如何与 gorm 中的多个关系一起工作?

来源:stackoverflow

时间:2024-04-07 21:51:32 312浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《如何与 gorm 中的多个关系一起工作?》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

import (
    "gorm.io/gorm"
    "gorm.io/driver/postgres"
)

type School struct {
    gorm.Model
    Students        []Student      `json:"students"`
}

type Student struct {
    gorm.Model
    Name            string         `json:"name"`
}

func init() {
    //connect to db first
    conn, err := gorm.Open(postgres.New(postgres.Config{
        DSN:                  dbUri,
        PreferSimpleProtocol: true,
    }), &gorm.Config{})
    if err != nil {
        log.Fatal(err)
    }

    db = conn
    db.AutoMigrate(&Student{}, &School{})
}

创建结构并自动迁移它会给我一个错误。你知道这是为什么吗?另外,如何使用 gorm 中有很多关系,它在 postgres 中创建什么样的数据?

错误 - 需要为关系定义有效的外键或者需要实现 valuer/scanner 接口


正确答案


您需要将 schoolid 字段添加到您的 student。完整使用请参阅 docs here

type Student struct {
    gorm.Model
    SchoolID        uint
    Name            string         `json:"name"`
}

为了回答第二部分,它将为您创建两个表。学校和学生。学生将拥有一个指向学校 id 的外键。我想了解更多信息,请拨打 read the docs

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何与 gorm 中的多个关系一起工作?》文章吧,也可关注golang学习网公众号了解相关技术文章。

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