如何解决pq:在表上插入或更新违反外键约束
尝试将gqlgen
与sqlx
一起使用。 gqlgen
生成了todo
和user
结构:
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
}
pq: insert or update on table "todos" violates foreign key constraint "todos_user_id_fkey"
我在哪里做错了?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。