Как сохранить отношения один на один с Гормом? - PullRequest
0 голосов
/ 13 января 2020

Как сохранить адресное отношение пользователя с помощью Gorm и Postgres?

package main

import (
    "fmt"
    "log"

    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/postgres"
)

var (
    pgUri = "postgres://postgres@127.0.0.1:5432/postgres?sslmode=disable"
)

type User struct {
    gorm.Model
    Email   string
    Address Address
}

type Address struct {
    gorm.Model
    Street  string
    City    string
    Country string
}

func main() {
    db, err := gorm.Open("postgres", pgUri)
    if err != nil {
        log.Fatalf("Failed to connect Postgres: %v\n", err)
    }

    // Checked two tables (user, address) created in database
    db.AutoMigrate(&User{}, &Address{})
    defer db.Close()

    u := User{
        Email: "some@one.com",
        Address: Address{
            Street:  "One street",
            City:    "Two city",
            Country: "Three country",
        },
    }

    fmt.Println(u)

    if err := db.Create(&u).Error; err != nil {
        panic(err)
    }

    if err := db.Save(&u).Error; err != nil {
        panic(err)
    }
}

После запуска с помощью go run main.go:

{{0 0001-01-01 00:00:00 +0000 UTC 0001-01-01 00:00:00 +0000 UTC <nil>} some@one.com {{0 0001-01-01 00:00:00 +0000 UTC 0001-01-01 00:00:00 +0000 UTC <nil>} One street Two city Three country}}

Создается новый пользователь, но не создает адреса .

1 Ответ

1 голос
/ 13 января 2020

Вам не хватает внешнего ключа в ассоциации Address. Если отношение имеет одно, поле внешнего ключа должно существовать, владелец сохранит первичный ключ модели, которой он принадлежит, в это поле.

Do c

type User struct {
    gorm.Model
    Email   string
    Address Address // One-To-One relationship (has one - use Address's UserID as foreign key)
}

type Address struct {
    gorm.Model
    UserID  uint
    Street  string
    City    string
    Country string
}
...