如何在一个GQL突变中建立多个连接?

时间:2019-04-10 21:47:24

标签: javascript node.js reactjs apollo-server prisma-graphql

所以我的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,但是连接没有更新的结果相同。

1 个答案:

答案 0 :(得分:0)

问题似乎有两个方面。

关于根本看不到任何变化:

在编写的变异中,games被添加到data之外的异步请求json中,这意味着该请求将永远找不到数据。 而不是:

data: ...,
games: ...

games必须是数据的一部分,例如:

data: {
  games: ...
}

关于要进行多个连接:

GraphQL使用以下连接语法支持这种嵌套更新样式:

connect: [
  { id : /* id from args */ },
  { id : /* another id from args */ },
  ...
]