проверьте, существует ли запись с помощью prisma graphql apollo

#graphql #apollo-server #prisma

Вопрос:

пытаюсь проверить, существует ли запись в таблице в Postgres с помощью Prisma, но , похоже, я могу запросить только поле идентификатора, но не любые другие поля, такие как name и location , что приводит к ошибке компилятора

Модель schema.prisma

 model place {
  id             Int              @id @default(dbgenerated("nextval('place_id_seq'::regclass)"))
  name           String
  location       String @unique
}
 

сгенерированный тип

 export type Place = {
  __typename?: 'Place';
  name?: Maybe<Scalars['String']>;
  location?: Maybe<Scalars['String']>;

};
 

Распознаватель запросов

 let findPlace = await prisma.place.findUnique(
        {
          where: {
            name: "abc"
          }
        }
)
 

ошибка

 Type '{ name: string; }' is not assignable to type 'placeWhereUniqueInput'.
  Object literal may only specify known properties, and 'name' does not exist in type 'placeWhereUniqueInput'.ts(2322)
index.d.ts(1361, 5): The expected type comes from property 'where' which is declared here on type '{ select?: placeSelect | null | undefined; include?: placeInclude | null | undefined; rejectOnNotFound?: RejectOnNotFound | undefined; where: placeWhereUniqueInput; }'
 

чего здесь не хватает, чтобы это сработало?

Ответ №1:

Prisma не будет принимать findUnique запросы, в которых условие содержит только не уникальные поля (в данном случае имя). Если вам просто нужно выяснить, существует ли запись места с соответствующим условием или нет, вы можете использовать count API.

 let placeCount = await prisma.place.count(
        {
          where: {
            name: "abc"
          }
        }
)
// placeCount == 0 implies does not exist