嵌套对象上具有冲突约束的Upsert Graphql变异
我正试图在一个突变中做一个逆转。这里我有两个表Users table[id,isVerified,type]和Customers table[id,name,deviceToken],Customers.id是Users.id的外键。嵌套对象上具有冲突约束的Upsert Graphql变异,graphql,mutation,hasura,Graphql,Mutation,Hasura,我正试图在一个突变中做一个逆转。这里我有两个表Users table[id,isVerified,type]和Customers table[id,name,deviceToken],Customers.id是Users.id的外键。 以下是突变- MyMutation { insert_Users(objects: [{isVerified: false, name: "+9100000000", type: "customer", Cu
以下是突变-
MyMutation {
insert_Users(objects: [{isVerified: false, name: "+9100000000", type: "customer",
Customers: {data: {deviceToken: "TestToken001"}}}],
on_conflict: {
constraint: Users_name_key,
update_columns: [isVerified]
}) {
affected_rows
returning {
Customers{
deviceToken
}
}
}
} ```
//But when I run this, I get the exception
{
"errors": [
{
"extensions": {
"path": "$.selectionSet.insert_Users.args.objects[0].Customers.data",
"code": "constraint-violation"
},
"message": "Uniqueness violation. duplicate key value violates unique constraint \"Customers_pkey\""
}
]
}
这似乎是因为我没有在嵌套的Customers对象上设置冲突约束。如何为嵌套对象添加冲突约束?您还需要在嵌套数据中添加约束对象。 比如:
MyMutation {
insert_Users(objects: [{isVerified: false, name: "+9100000000", type: "customer",
Customers: {
data: {deviceToken: "TestToken001"},
on_conflict: {
constraint: Customers_pkey,
update_columns: [deviceToken]
}
}}],
on_conflict: {
constraint: Users_name_key,
update_columns: [isVerified]
}) {
affected_rows
returning {
Customers{
deviceToken
}
}
}
}