所以我的Prisma数据模型中有以下内容。游戏与角色之间存在关系,角色可以出现在多个游戏中。此外,仅在查询游戏时,就应该能够在游戏中列出角色:
type Game {
id: ID! @unique
name: String! @unique
name_ja: String @unique
name_ko: String @unique
name_zh_CN: String @unique
name_zh_TW: String @unique
name_zh_HK: String @unique
characters: [Character]
filters: [GameFilter]
}
type Character {
id: ID! @unique
name: String! @unique
name_ja: String @unique
name_ko: String @unique
name_zh_CN: String @unique
name_zh_TW: String @unique
name_zh_HK: String @unique
games: [Game]
}
然后我将其作为更新我的架构中字符的一种方式。我传递了一系列游戏ID,因为有可能在同一个变异中添加多个游戏:
updateCharacter(
name: String
name_ja: String
name_ko: String
name_zh_CN: String
name_zh_HK: String
name_zh_TW: String
id: ID!
games: [ID]
): Character!
并写出以下突变:
async updateCharacter(parent, args, ctx, info) {
if (!ctx.request.userId) {
throw new Error('You must be logged in');
}
const updates = {...args};
delete updates.id;
delete updates.games;
console.log(args.games);
const res = await ctx.db.mutation.updateCharacter({
data: updates,
games: {
connect: {
id: args.games
}
},
where: {
id: args.id
}
}, info);
return res;
}
然后将以下突变写在React端。这是为了将ID数组传递给突变(这是可以预期的,因为该模式假定ID数组将被传递:
const UPDATE_CHARACTER_MUTATION = gql`
mutation UPDATE_CHARACTER_MUTATION(
$name: String!
$name_ja: String!
$name_ko: String!
$name_zh_CN: String!
$name_zh_TW: String!
$name_zh_HK: String!
$id: ID!
$games: [ID]!
) {
updateCharacter(
name: $name
name_ja: $name_ja
name_ko: $name_ko
name_zh_CN: $name_zh_CN
name_zh_TW: $name_zh_TW
name_zh_HK: $name_zh_HK
games: $games
id: $id
) {
id
name
name_ja
name_ko
name_zh_CN
name_zh_TW
name_zh_HK
games {
id
name
}
}
}
`;
我还在表单中的onSubmit数组中传递了游戏的ID。
结果是该突变通过了,但只会更新名称字段,并且与游戏的连接保持不变。
不确定如何做才能正确地使其变异。我不确定是否将数组直接传递给连接中的突变是造成此问题的原因,但是我尝试分别映射并传递每个游戏ID,但是连接没有更新的结果相同。
答案 0 :(得分:0)
问题似乎有两个方面。
关于根本看不到任何变化:
在编写的变异中,games
被添加到data
之外的异步请求json中,这意味着该请求将永远找不到数据。
而不是:
data: ...,
games: ...
games
必须是数据的一部分,例如:
data: {
games: ...
}
关于要进行多个连接:
GraphQL使用以下连接语法支持这种嵌套更新样式:
connect: [
{ id : /* id from args */ },
{ id : /* another id from args */ },
...
]