如何删除有关系的项目?

问题描述 投票:0回答:1

我正在使用prisma2,我不知道如何删除与其他模型有关系的项目。

这是我的模型。

model User {
  id       String @default(cuid()) @id
  email    String @unique
  password String
  name     String

  teams       Team[]
  memberships Membership[]
}

model Team {
  id        String   @default(cuid()) @id

  name        String
  founder     User?
  memberships Membership[]
}

model Membership {
  id        String   @default(cuid()) @id

  class    String

  owner User
  team  Team
}

用户-团队是1:n的关系。 团队成员关系是 1:n 的关系。

我想删除一个团队。

我已经尝试过了。

t.list.field("deleteTeam", {
  type: "Team",
  args: {
    teamid: idArg()
  },
  resolve: (_, { teamid }, ctx) => {
    return ctx.photon.teams.deleteMany({
      where: { id: teamid }
    });
  }
});

但是它不起作用,因为它违反了关系。

如何在删除团队的同时断开所有关系?

graphql prisma prisma-graphql nexus-prisma
1个回答
2
投票

具有依赖关系的删除通常需要指定级联删除。

根据您的模型,我相信您需要更新您的 graphql 模式来处理

CASCADE
上的
SET_NULL
关系
onDelete

我知道在像8base这样的其他系统中,有一个

force: Boolean
标志可以指定来解决这个问题。但是,这里是解决您问题的 Prisma 文档部分:https://prisma-docs.netlify.com/docs/1.4/reference/prisma-api/concepts-utee3eiquo/#cascading-deletes

© www.soinside.com 2019 - 2024. All rights reserved.