3

我想创建一个附有标签列表的帖子。模型是多对多连接的(一个帖子可以有多个标签,一个标签可以有多个帖子)。

这是我的棱镜模型:

model Post {
  id String @id @default(cuid())
  slug String @unique
  title String
  body String
  tags Tag[]
}

model Tag {
  id String @id @default(cuid())
  posts Post[]
  name String
  slug String @unique
}

这是一个突变,我正在尝试创建一个帖子,并为其附加标签:

t.field('createPost', {
  type: 'Post',
  args: {
    title: nonNull(stringArg()),
    body: stringArg(),
    tags: list(arg({ type: 'TagInput' }))
  },
  resolve: async (_, args, context: Context) => {
    // Create tags if they don't exist
    const tags = await Promise.all(
      args.tags.map((tag) =>
        context.prisma.tag.upsert({
          create: omit(tag, "id"),
          update: tag,
          where: { id: tag.id || "" },
        })
      )
    )
    return context.prisma.post.create({
      data: {
        title: args.title,
        body: args.body,
        slug: `${slugify(args.title)}-${cuid()}`,
        // Trying to connect a post to an already existing tag
        // Without the "tags: {...} everything works
        tags: {
          set: [{id:"ckql6n0i40000of9yzi6d8bv5"}]
        },
        authorId: getUserId(context),
        published: true, // make it false once Edit post works.
      },
    })
  },
})

这似乎不起作用。

我收到一个错误:

Invalid `prisma.post.create()` invocation:
{
  data: {
    title: 'Post with tags',
    body: 'Post with tags body',
    slug: 'Post-with-tags-ckql7jy850003uz9y8xri51zf',
    tags: {
      connect: [
        {
          id: 'ckql6n0i40000of9yzi6d8bv5'
        }
      ]
    },
  }
}
Unknown arg `tags` in data.tags for type PostUncheckedCreateInput. Available args:
type PostUncheckedCreateInput {
  id?: String
  title: String
  body: String
  slug: String
}

好像tags帖子上的字段不见了?但我确实跑prisma generateprisma migrate。如果我使用 Prisma Studio 手动添加标签,我也可以成功查询帖子上的标签。什么可能导致此问题?

4

2 回答 2

1

您也需要使用connectauthor所以以下将正常工作:

return context.prisma.post.create({
      data: {
        title: args.title,
        body: args.body,
        slug: `${slugify(args.title)}-${cuid()}`,
        // Trying to connect a post to an already existing tag
        // Without the "tags: {...} everything works
        tags: {
          set: [{id:"ckql6n0i40000of9yzi6d8bv5"}]
        },
        author: { connect: { id: getUserId(context) } },
        published: true, // make it false once Edit post works.
      },
})
于 2021-07-02T05:17:42.447 回答
0

就我而言,当我在 prisma 模型上创建一个名为 uid 的新字段并尝试运行命令时,问题就出现了prisma migrate dev

它带来了错误

Error:
⚠️ We found changes that cannot be executed:

  • Step 0 Added the required column `uid` to the `Transactions` table without a default value. There are 1 rows in this table, it is not possible to execute this step.

You can use prisma migrate dev --create-only to create the migration file, and manually modify it to address the underlying issue(s).
Then run prisma migrate dev to apply it and verify it works.

我通过添加它来解决@default("")它。

model Transactions {
  id Int @id @default(autoincrement())
  uid String @default("")
  account String
  description String
  category String
  reference String
  currency String @default("GBP")
  amount String
  status String
  transactionDate String
  createdAt String
  updatedAt String
}
于 2021-10-11T10:53:48.680 回答