Server/prisma/schema.prisma

107 lines
2.9 KiB
Plaintext
Raw Normal View History

2024-11-25 12:17:49 +00:00
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "mysql"
2024-11-25 12:17:49 +00:00
url = env("DATABASE_URL")
}
model User {
id String @id
username String
createdAt DateTime @default(now())
Class Class[]
SentMessages UserMessage[] @relation("SentMessages")
ReceivedMessages UserMessage[] @relation("ReceivedMessages")
RoomSurveyAnswerUser RoomSurveyAnswerUser[]
RoomPresentator Room[] @relation("Presentator")
}
model UserMessage {
id Int @id @default(autoincrement())
content String
sender User @relation(fields: [sender_user_Id], references: [id], name: "SentMessages")
sender_user_Id String
receiver User @relation(fields: [receiver_user_Id], references: [id], name: "ReceivedMessages")
receiver_user_Id String
createdAt DateTime @default(now())
}
model Class {
id String @id @default(cuid())
name String @unique
createdAt DateTime @default(now())
ClassRoom Room[]
Students User[]
}
model Room {
id String @id @default(cuid())
name String
2025-01-09 22:13:48 +00:00
date DateTime @db.Date
Presentator User @relation("Presentator", fields: [presentatorId], references: [id])
presentatorId String
Class Class[]
Messages RoomMessage[]
Documents RoomDocument[]
Surveys RoomSurvey[]
Times RoomTime[]
}
model RoomTime {
id Int @id @default(autoincrement())
2025-01-09 22:13:48 +00:00
startTime DateTime @db.Time
endTime DateTime @db.Time
Room Room @relation(fields: [roomId], references: [id], onDelete: Cascade)
roomId String
}
model RoomMessage {
id Int @id @default(autoincrement())
content String
Room Room @relation(fields: [roomId], references: [id], onDelete: Cascade)
roomId String
}
model RoomDocument {
id Int @id @default(autoincrement())
content String
Room Room @relation(fields: [roomId], references: [id], onDelete: Cascade)
roomId String
}
model RoomSurvey {
id Int @id @default(autoincrement())
content String
Room Room @relation(fields: [roomId], references: [id], onDelete: Cascade)
roomId String
createdAt DateTime @default(now())
endAt DateTime?
Answers RoomSurveyAnswer[]
}
model RoomSurveyAnswer {
id Int @id @default(autoincrement())
content String
Survey RoomSurvey @relation(fields: [surveyId], references: [id])
surveyId Int
isRight Boolean
Users RoomSurveyAnswerUser[]
}
model RoomSurveyAnswerUser {
id Int @id @default(autoincrement())
User User @relation(fields: [userId], references: [id])
userId String
Answer RoomSurveyAnswer @relation(fields: [answerId], references: [id])
answerId Int
2025-01-09 22:13:48 +00:00
}