Как правильно использовать FirstOrCreate - PullRequest
0 голосов
/ 24 сентября 2018

У меня есть следующая простая структура

type Profile struct {
    gorm.Model

    Email     string    `json:"email" sql:"not null;unique"`
    LastLogin time.Time `json:"lastlogin"`
}

Я пытаюсь сделать вставку, если она не существует через

  db.Con.Debug().Where(db.Profile{Email: "user@domain.com"}).Assign(db.Profile{LastLogin: time.Now()}).FirstOrCreate(&profile)

Я получаю следующее в моих журналах

(/Users/mzupan/go/src/gitlab.com/org/app/pkg/auth/login.go:182)
[2018-09-24 13:35:58]  [4.56ms]  SELECT * FROM "profiles"  WHERE "profiles"."deleted_at" IS NULL AND (("profiles"."email" = 'user@domain.com')) ORDER BY "profiles"."id" ASC LIMIT 1
[0 rows affected or returned ]

(/Users/mzupan/go/src/gitlab.com/org/app/pkg/auth/login.go:182)
[2018-09-24 13:35:58]  [1.77ms]  UPDATE "profiles" SET "last_login" = '2018-09-24 13:35:58', "updated_at" = '2018-09-24 13:35:58'  WHERE "profiles"."deleted_at" IS NULL AND (("profiles"."email" = 'user@domain.com'))
[0 rows affected or returned ]

Таким образом, он пытается выполнить выбор / обновление, даже если в выборке найдено 0 строк.Мне кажется, я поступаю правильно.

1 Ответ

0 голосов
/ 25 сентября 2018

Я думаю, что вы забыли создать таблицу db.CreateTable(&Profile{})

Вот рабочий пример:

package main

import (
    "time"

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

type Profile struct {
    gorm.Model

    Email     string    `json:"email" sql:"not null;unique"`
    LastLogin time.Time `json:"lastlogin"`
}

func main() {
    db, err := gorm.Open("sqlite3", "test.db")
    if err != nil {
        panic("failed to connect database")
    }
    defer db.Close()
    // Create the table...
    // Read the doc at: http://doc.gorm.io/database.html#migration -> sec: Create Table
    db.CreateTable(&Profile{})

    var profile Profile
    db.Debug().Where(Profile{Email: "user@domain.com"}).Assign(Profile{LastLogin: time.Now()}).FirstOrCreate(&profile)
}

Out put:

[2018-09-25 09:47:35]  [0.18ms]  INSERT INTO "profiles" ("created_at","updated_at","deleted_at","email","last_login") VALUES ('2018-09-25 09:47:35','2018-09-25 09:47:35',NULL,'user@domain.com','2018-09-25 09:47:35')
[1 rows affected or returned ]

Надеюсь, что это поможет:)

...