【问题标题】:Foreign key in gormgorm中的外键
【发布时间】:2021-07-06 16:40:56
【问题描述】:

这是我的代码:

package main

import (
    "fmt"
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/sqlite"
)

type Mongo struct {
    gorm.Model
    Url      string
    Login    string
    Password string
    Env     string
    Base string
    Port string
}

type MicroService struct {
    gorm.Model
    Url        string
    Port       string
    Version    string
    Name       string
    Etat       string
    MongoDb    Mongo `gorm:"foreignkey:MongoId"`
    MongoId int
    Env     string
}

func initDb() {
    var mongoDb Mongo
    result := db.Find(&mongoDb, "env = ?", "Prod").RecordNotFound()
    fmt.Println("not found create mongodb")
    fmt.Println(result)
    if result == true {
        mongoDb = Mongo{}
        // "mongodb://heroku_4n1snp42:f42hkq6n3qfv48uelms7vrclta@:23930/heroku_4n1snp42"
        mongoDb.Url = "mlab.com"
        mongoDb.Login = "toto"
        mongoDb.Password = "titi"
        mongoDb.Base = "tata"
        mongoDb.Port = "23930"
        mongoDb.Env = "Prod"
        db.Create(&mongoDb)
    }
    var microService MicroService
    result = db.Find(&microService, "name = ? and env = ?", "constructProduct","Prod").RecordNotFound()
    fmt.Println("not found create construct Product Micro")
    fmt.Println(result)
    if result == true {
        microService = MicroService{}
        microService.Name  = "totobis"
        microService.Port = "8307"
        microService.Env = "Prod"
        var mongoDbConstructProduct Mongo
        result = db.Find(&mongoDbConstructProduct , "env = ?", "Prod").RecordNotFound()
        fmt.Println(mongoDbConstructProduct)
        microService.MongoDb = mongoDbConstructProduct
        db.Create(&microService)
        fmt.Println("constructProduct microservice created")
    }
}

var db *gorm.DB
var loggued bool

func main() {
    var err error
    loggued = false
    db, err = gorm.Open("sqlite3", "configuration.sqlite3?cache=shared&mode=rwc")
    db.AutoMigrate(&MicroService{})
    db.AutoMigrate(&Mongo{})

    initDb()
    var microService MicroService
    db.Find(&microService, "name = ?", "totobis").RecordNotFound()
    if err != nil {
        panic("failed to connect database")
    }
    defer db.Close()
    fmt.Println(microService)
}

但是我不明白为什么我查询后打印对象,微服务的mongodb是空的。

当我在创建时打印字段 mongodb 就可以了:

{{1 2018-11-26 22:08:16.436503737 +0100 +0100 2018-11-26 22:08:16.504275897 +0100 +0100 } mlab.com toto titi Prod tata 23930}

但是当我尝试重新创建一个微服务对象时,mongo 字段是空的:

{{2 2018-11-26 22:09:15.73203579 +0100 +0100 2018-11-26 22:09:15.73203579 +0100 +0100 } 8307 totobis {{0 0001-01-01 00:00:00 +0000 UTC 0001-01-01 00:00:00 +0000 UTC } } 1 产品}

如何才能使用我关联的 mongo 结构获得良好的微服务结构?

【问题讨论】:

    标签: go go-gorm


    【解决方案1】:

    MongoId 是 uint 数据类型,而不是 int

    在另一种方式中,您可以在 Mongo 模型中使用 int 字段:

    type Mongo struct {
    gorm.Model
    Ms int // for example
    ....
    }
    

    然后在微服务模型中:

    type MicroService struct {
    gorm.Model
    Url        string
    Port       string
    Version    string
    Name       string
    Etat       string
    MongoDb    Mongo `gorm:"foreignkey:MongoId;association_foreignkey:Ms"`
    MongoId int
    Env     string
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-07-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-05-18
      • 1970-01-01
      • 2021-03-25
      • 2020-11-11
      相关资源
      最近更新 更多