mi-gpt/prisma/schema.prisma

102 lines
3.4 KiB
Plaintext
Raw Normal View History

2024-01-25 18:06:22 +00:00
// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "sqlite"
2024-02-27 17:21:30 +00:00
url = "file:app.db"
2024-01-25 18:06:22 +00:00
}
model User {
id String @id @default(uuid())
name String
profile String
2024-01-28 06:52:32 +00:00
// 关联数据
rooms Room[] @relation("RoomMembers")
messages Message[]
memories Memory[]
shortTermMemories ShortTermMemory[]
longTermMemories LongTermMemory[]
// 时间日期
2024-01-25 18:06:22 +00:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
2024-01-28 06:52:32 +00:00
}
model Room {
id String @id @default(uuid())
name String
description String
// 关联数据
members User[] @relation("RoomMembers")
2024-01-25 18:06:22 +00:00
messages Message[]
memories Memory[]
shortTermMemories ShortTermMemory[]
longTermMemories LongTermMemory[]
2024-01-28 06:52:32 +00:00
// 时间日期
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
2024-01-25 18:06:22 +00:00
}
model Message {
id Int @id @default(autoincrement())
text String
2024-01-28 06:52:32 +00:00
// 关联数据
2024-01-25 18:06:22 +00:00
sender User @relation(fields: [senderId], references: [id])
2024-01-28 06:52:32 +00:00
senderId String
room Room @relation(fields: [roomId], references: [id])
roomId String
memories Memory[]
2024-01-28 06:52:32 +00:00
// 时间日期
2024-01-25 18:06:22 +00:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model Memory {
id Int @id @default(autoincrement())
2024-01-28 06:52:32 +00:00
// 关联数据
msg Message @relation(fields: [msgId], references: [id])
msgId Int
2024-01-28 06:52:32 +00:00
owner User? @relation(fields: [ownerId], references: [id]) // owner 为空时,即房间自己的公共记忆
ownerId String?
room Room @relation(fields: [roomId], references: [id])
2024-01-28 06:52:32 +00:00
roomId String
shortTermMemories ShortTermMemory[]
// 时间日期
2024-01-25 18:06:22 +00:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model ShortTermMemory {
id Int @id @default(autoincrement())
2024-01-28 06:52:32 +00:00
text String
// 关联数据
cursor Memory @relation(fields: [cursorId], references: [id]) // 记忆最后更新的位置
2024-01-25 18:06:22 +00:00
cursorId Int
2024-01-28 06:52:32 +00:00
owner User? @relation(fields: [ownerId], references: [id]) // owner 为空时,即房间自己的公共记忆
ownerId String?
room Room @relation(fields: [roomId], references: [id])
2024-01-28 06:52:32 +00:00
roomId String
2024-01-25 18:06:22 +00:00
longTermMemories LongTermMemory[]
2024-01-28 06:52:32 +00:00
// 时间日期
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
2024-01-25 18:06:22 +00:00
}
model LongTermMemory {
id Int @id @default(autoincrement())
2024-01-28 06:52:32 +00:00
text String
// 关联数据
2024-01-25 18:06:22 +00:00
cursor ShortTermMemory @relation(fields: [cursorId], references: [id])
2024-01-28 06:52:32 +00:00
cursorId Int
owner User? @relation(fields: [ownerId], references: [id]) // owner 为空时,即房间自己的公共记忆
ownerId String?
room Room @relation(fields: [roomId], references: [id])
roomId String
// 时间日期
2024-01-25 18:06:22 +00:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}