Maison  >  Questions et réponses  >  le corps du texte

Système de gestion de salle Prisma

J'essaie de créer une base de données pour un système de gestion de salle mais je suis confus quant aux relations et je ne trouve aucune ressource utile sur Internet, pouvez-vous me dire s'il y a un problème avec ce script prisma ? Parce que je veux le contrôler dans expressJs et créer une application basée sur celui-ci

generator client {
  provider = "prisma-client-js"
}

datasource db {
  provider = "mysql"
  url      = env("DATABASE_URL")
}

model Guest {
  guestId     String        @id @default(uuid())
  name        String
  phone       String        @unique()
  address     String?
  nationality String
  Reservation Reservation[] @relation("GuestReservation")
}

model Reservation {
  reservationId Int             @id @default(autoincrement())
  checkIn       DateTime
  checkOut      DateTime
  Guest         Guest           @relation("GuestReservation", fields: [guestId], references: [guestId], onDelete: Cascade)
  guestId       String
  visitors      Int
  Room          Room            @relation("RoomReservation", fields: [roomId], references: [roomId], onDelete: Cascade)
  type          ReservationType
  roomId        Int
  Bill          Bill?           @relation("BillReservation")
}

enum ReservationType {
  Booking
  Contract
  Booked
  Canceled
}

model Room {
  roomId      Int           @id @default(autoincrement())
  price       Float
  type        Type
  Reservation Reservation[] @relation("RoomReservation")
}

enum Type {
  Single
  Double
  Triple
}

model Bill {
  invoiceNo     String      @id @default(uuid())
  Reservation   Reservation @relation("BillReservation", fields: [reservationId], references: [reservationId], onDelete: Cascade)
  reservationId Int         @unique()
  roomService   Float       @default(0)
  paymentMode   Payment
  Service       Service[]
}

enum Payment {
  Cash
  Visa
}

model Service {
  serviceId     String      @id @default(uuid())
  type          ServiceType
  name          String
  price         Float
  Bill          Bill        @relation(fields: [billInvoiceNo], references: [invoiceNo], onDelete: Cascade)
  billInvoiceNo String
}

enum ServiceType {
  Bar
  Laundry
}

J'ai essayé d'en créer une approximation pour chaque entité, mais j'ai fini par obtenir des erreurs de relation, comme des clés étrangères ou quelque chose du genre, ce qui signifiait qu'il y avait quelque chose qui n'allait pas dans ma relation.

P粉819937486P粉819937486186 Il y a quelques jours414

répondre à tous(1)je répondrai

  • P粉037450467

    P粉0374504672024-03-31 00:31:33

    Votre schéma est valide, mais je recommande de maintenir la cohérence lors de la définition des identifiants des tables. Certains ID de table sont des types de chaîne et certains ID de table sont des types numériques.

    Ce qui suit est un exemple de requête pour créer des entités pour le modèle.

    import {
      PrismaClient,
      Type,
      ServiceType,
      Payment,
      ReservationType,
    } from '@prisma/client';
    
    const prisma = new PrismaClient({
      log: ['query'],
    });
    
    async function main() {
      // Creating a room
      await prisma.room.create({
        data: {
          price: 100,
          type: Type.Single,
          roomId: 1,
        },
      });
    
      // Creating a guest
      await prisma.guest.create({
        data: {
          name: 'Test',
          nationality: 'Indian',
          phone: '1234567890',
          address: 'Test Address',
          guestId: '1',
        },
      });
    
      // Creating a service with a bill and a reservation
      await prisma.service.create({
        data: {
          name: 'test',
          price: 100,
          type: ServiceType.Bar,
          serviceId: '1',
          Bill: {
            create: {
              paymentMode: Payment.Cash,
              invoiceNo: '1',
              Reservation: {
                create: {
                  checkIn: new Date(),
                  checkOut: new Date(),
                  type: ReservationType.Booked,
                  visitors: 1,
                  roomId: 1,
                  guestId: '1',
                },
              },
            },
          },
        },
      });
    }
    
    main()
      .catch((e) => {
        throw e;
      })
      .finally(async () => {
        await prisma.$disconnect();
      });
    
    

    Voici la réponse à la requête :

    > ts-node index.ts
    prisma:query BEGIN
    prisma:query INSERT INTO `white_egret`.`Room` (`roomId`,`price`,`type`) VALUES (?,?,?)
    prisma:query SELECT `white_egret`.`Room`.`roomId`, `white_egret`.`Room`.`price`, `white_egret`.`Room`.`type` FROM `white_egret`.`Room` WHERE `white_egret`.`Room`.`roomId` = ? LIMIT ? OFFSET ?
    prisma:query COMMIT
    prisma:query BEGIN
    prisma:query INSERT INTO `white_egret`.`Guest` (`guestId`,`name`,`phone`,`address`,`nationality`) VALUES (?,?,?,?,?)
    prisma:query SELECT `white_egret`.`Guest`.`guestId`, `white_egret`.`Guest`.`name`, `white_egret`.`Guest`.`phone`, `white_egret`.`Guest`.`address`, `white_egret`.`Guest`.`nationality` FROM `white_egret`.`Guest` WHERE `white_egret`.`Guest`.`guestId` = ? LIMIT ? OFFSET ?
    prisma:query COMMIT
    prisma:query BEGIN
    prisma:query INSERT INTO `white_egret`.`Reservation` (`reservationId`,`checkIn`,`checkOut`,`guestId`,`visitors`,`type`,`roomId`) VALUES (?,?,?,?,?,?,?)
    prisma:query INSERT INTO `white_egret`.`Bill` (`invoiceNo`,`reservationId`,`roomService`,`paymentMode`) VALUES (?,?,?,?)
    prisma:query INSERT INTO `white_egret`.`Service` (`serviceId`,`type`,`name`,`price`,`billInvoiceNo`) VALUES (?,?,?,?,?)
    prisma:query SELECT `white_egret`.`Service`.`serviceId`, `white_egret`.`Service`.`type`, `white_egret`.`Service`.`name`, `white_egret`.`Service`.`price`, `white_egret`.`Service`.`billInvoiceNo` FROM `white_egret`.`Service` WHERE `white_egret`.`Service`.`serviceId` = ? LIMIT ? OFFSET ?
    prisma:query COMMIT

    répondre
    0
  • Annulerrépondre