登录
首页 >  Golang >  Go问答

GORM 禁止生成外键

来源:stackoverflow

时间:2024-03-02 16:48:24 176浏览 收藏

珍惜时间,勤奋学习!今天给大家带来《GORM 禁止生成外键》,正文内容主要涉及到等等,如果你正在学习Golang,或者是对Golang有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望都能帮到正在学习的大家!

问题内容

我正在尝试使用 go 和 gorm 在 postgresql 数据库上设置两个模型之间的关系。

这是我的代码,第一个模型:

trip.go

package model

import "github.com/jinzhu/gorm"

// trip models
type trip struct {
    gorm.model
    tripname        string
    tripdescription string
}

第二个模型:

tripkeypoints.go

package model

import "github.com/jinzhu/gorm"

// tripkeypoint models
type tripkeypoint struct {
    gorm.model
    kpname        string
    kpdescription string
    tripid        trip
}

运行迁移并初始化所有文件的部分代码

    db.droptableifexists(&user{}, &model.trip{}, &model.tripkeypoint{})
    db.automigrate(&user{}, &model.trip{}, &model.tripkeypoint{})
    db.model(&model.tripkeypoint{}).addforeignkey("trip_id", "trips(id)", "cascade", "cascade")

用户模型只是一个插件,但我把它留在这个片段中。 由于经过多次测试,我在一开始就放弃了表格。

这是我运行代码时收到的内容:

?[35m(C:/golang_lab/golang-gorm-tutorial/users.go:36)?[0m
?[33m[2019-09-21 18:40:34]?[0m ?[31;1m pq: column "trip_id" referenced in foreign key constraint does not exist ?[0m

是的,确实如此,当我登录到 postgres 时,表 trip_key_points 中没有带有外键的列。

我需要做的是,我想要一个 trip 对象,然后分配其他 tripkeypoints。

知道为什么吗?或者我如何强制 gorm 创建此列?


解决方案


我明确定义外键列:

// tripkeypoint models
type tripkeypoint struct {
    gorm.model
    kpname        string
    kpdescription string
    tripid        uint `gorm:"type:integer references trips"`
}

尝试像这样编辑你的结构:

// TripKeyPoint models
type TripKeyPoint struct {
    gorm.Model
    KPName        string
    KPDescription string
    TripID        Trip `gorm:"foreignkey:TripId"`
}

本篇关于《GORM 禁止生成外键》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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