pq:在表上插入或更新违反外键约束

问题描述

尝试将gqlgensqlx一起使用。 gqlgen生成了todouser结构:

package model

type NewTodo struct {
    Text   string `json:"text" db:"text"`
    UserID int64  `json:"user_id" db:"user_id"`
}

type Todo struct {
    ID   int64  `json:"id"`
    Text string `json:"text" db:"text"`
    Done bool   `json:"done" db:"done"`
    User *User  `json:"user"`
}

type User struct {
    ID   int64  `json:"id"`
    Name string `json:"name" db:"name"`
}

这是数据库(postgres)模式:

var Schema = `
    CREATE TABLE users (
        id BIGSERIAL PRIMARY KEY,name VARCHAR(255),created_at TIMESTAMPTZ NOT NULL DEFAULT (now()),updated_at TIMESTAMPTZ NOT NULL DEFAULT (now())
    );

    CREATE TABLE todos (
        id BIGSERIAL PRIMARY KEY,text TEXT,done BOOLEAN,user_id BIGINT NOT NULL REFERENCES users(id) ON DELETE CASCADE,updated_at TIMESTAMPTZ NOT NULL DEFAULT (now())
    );
`

这是插入突变/功能:

...

func (r *mutationResolver) CreateTodo(ctx context.Context,input model.NewTodo) (*model.Todo,error) {
    log.Println(" >> input.Text:",input.Text) // One Todo
    log.Println(" >> input.Text.Type:",reflect.TypeOf(input.Text)) // string
    log.Println(" >> input.UserID:",input.UserID) // 1
    log.Println(" >> input.UserID.Type:",reflect.TypeOf(input.UserID)) // int64

    db := db.Connect()
    tx := db.MustBegin()
    id,err := tx.MustExec("INSERT INTO todos (text,user_id) VALUES ($1,$2)",input.Text,input.UserID).LastInsertId()
    if err != nil {
        log.Fatalln(err)
    }
    tx.Commit()
    return &model.Todo{ID: id},nil
}

当我进行新的todo突变时,它将引发内部系统错误:

pq: insert or update on table "todos" violates foreign key constraint "todos_user_id_fkey"

我在哪里做错了?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...