微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决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 举报,一经查实,本站将立刻删除。