问题描述
尝试将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
}
当我进行新的todo突变时,它将引发内部系统错误:
pq: insert or update on table "todos" violates foreign key constraint "todos_user_id_fkey"
我在哪里做错了?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)