Как сохранить новую запись в Prisma без удостоверения личности? - PullRequest
0 голосов
/ 28 марта 2019

Я использую Prisma (https://www.prisma.io) в качестве ORM. Я хочу проверить наличие дубликатов при сохранении данных и, если не существует, создать новую запись.

Я думал, что смогу сделать это с помощью метода upsert, предоставленного Prisma и доступного в сгенерированном клиенте, но предложение where этого метода работает только с id (или полями @unique), но если запись не существует, там нет никакого идентификатора, чтобы предоставить.

Я привожу пример проблемы.

datamodel.prisma

type System {
  id: ID! @unique
  performances: [SystemPerformance!]! @relation(name: "PerformanceBySystem" onDelete: CASCADE)
  name: String! @unique
}

type SystemPerformance {
  id: ID! @unique
  system: System! @relation(name: "PerformanceBySystem")
  date: DateTime!
  perf1: Float
  perf2: Float
}

seed.js

const { prisma } = require('./generated/prisma-client');
async function main(){
  await prisma.createSystem({
    name: 's1',
  });
  await prisma.createSystem({
    name: 's2',
  });
  await prisma.createSystem({
    name: 's3',
  });
}
main();

После создания создается база данных с тремя системами без выступлений. Я пытаюсь вставить новый SystemPerformance, если нет таких, которые имеют ту же дату и ту же Систему. Я пытался

const { prisma } = require('./prisma/generated/prisma-client');

const perf = await prisma.upsertSystemPerformance({
       where: {
         system: {name: 's1'},
         date: "2019-03-12T00:01:06.000Z"
       },
       update: {
         perf1: 13.45,
         perf2: 18.93
       },
       create: {
        system: {
            connect: { name: 's1' }
        },
        date: "2019-03-12T00:01:06.000Z",
        perf1: 13.45,
        perf2: 18.93
       }
})

Но выдается исключение:

UnhandledPromiseRejectionWarning: Ошибка: переменная '$ где' ожидаемого значения типа 'SystemPerformanceWhereUniqueInput!' но получил: {"system": {"name": 's1'}, "date": "2019-03-12T00: 01: 06.000Z"}. Причина: 'system' Поле 'system' не определено в типе ввода 'SystemPerformanceWhereUniqueInput'

Единственное решение, которое я нашел, это проверка на существование и затем обновление или создание, но я хотел сделать это с помощью upsert.

let check = await prisma.$exists.SystemPerformance({
            system: {name: 's1'},
            date: "2019-03-12T00:01:06.000Z"
        });
let perfo;
if (check){
  const sysPerf = await prisma.systemPerformances({where:{system: {name: 's1'}, date: "2019-03-12T00:01:06.000Z"}})
            .$fragment(`
            {
                id
            }
            `);
  perfo = await prisma.updateSystemPerformance({
    where: {id: sysPerf[0].id},
            data: {
              perf1: 13.45,
              perf2: 18.93
            }
   })
}
else {
  perfo = await prisma.createSystemPerformance({
    system: {
      connect: { name: 's1' }
    },
    date: "2019-03-12T00:01:06.000Z",
    perf1: 13.45,
    perf2: 18.93
  }
})

Есть ли способ сделать это с помощью upsert?

...