Files
ai-portal/prisma/schema.prisma
T

82 lines
2.4 KiB
Plaintext
Raw Normal View History

2026-05-06 17:22:50 +08:00
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "sqlite"
url = env("DATABASE_URL")
}
model User {
id Int @id @default(autoincrement())
email String @unique
username String @unique
password String
name String?
role String @default("admin")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
2026-05-06 17:22:50 +08:00
conversations Conversation[]
}
model Category {
id Int @id @default(autoincrement())
name String @unique
2026-05-06 17:22:50 +08:00
icon String?
description String?
2026-05-06 17:22:50 +08:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
agents Agent[]
}
model Agent {
id Int @id @default(autoincrement())
name String
slug String @unique
description String
icon String?
categoryId Int?
features String @default("")
hotQuestions String @default("[]")
quickQuestions String @default("[]")
usageCount Int @default(0)
status String @default("active")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
category Category? @relation(fields: [categoryId], references: [id])
2026-05-06 17:22:50 +08:00
conversations Conversation[]
}
model News {
id Int @id @default(autoincrement())
title String
content String
type String @default("news")
published Boolean @default(false)
2026-05-06 17:22:50 +08:00
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model Conversation {
id Int @id @default(autoincrement())
2026-05-06 17:22:50 +08:00
agentId Int
userId Int?
title String @default("新对话")
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
user User? @relation(fields: [userId], references: [id])
agent Agent @relation(fields: [agentId], references: [id], onDelete: Cascade)
2026-05-06 17:22:50 +08:00
messages Message[]
}
model Message {
id Int @id @default(autoincrement())
2026-05-06 17:22:50 +08:00
conversationId Int
role String
2026-05-06 17:22:50 +08:00
content String
timestamp DateTime @default(now())
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)
2026-05-06 17:22:50 +08:00
}