training_data/packages/common/prisma/schema.prisma

286 lines
10 KiB
Plaintext
Raw Normal View History

2024-09-03 20:19:33 +08:00
// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema
generator client {
2024-12-30 08:26:40 +08:00
provider = "prisma-client-js"
2024-09-03 20:19:33 +08:00
}
datasource db {
2024-12-30 08:26:40 +08:00
provider = "postgresql"
url = env("DATABASE_URL")
2024-09-03 20:19:33 +08:00
}
model Taxonomy {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
name String @unique
slug String @unique @map("slug")
deletedAt DateTime? @map("deleted_at")
createdAt DateTime @default(now()) @map("created_at")
terms Term[]
objectType String[] @map("object_type")
order Float? @map("order")
2024-09-03 20:19:33 +08:00
2024-12-30 08:26:40 +08:00
@@index([order, deletedAt])
@@map("taxonomy")
2024-09-03 20:19:33 +08:00
}
model Term {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
name String
taxonomy Taxonomy? @relation(fields: [taxonomyId], references: [id])
taxonomyId String? @map("taxonomy_id")
order Float? @map("order")
description String?
parentId String? @map("parent_id")
parent Term? @relation("ChildParent", fields: [parentId], references: [id], onDelete: Cascade)
children Term[] @relation("ChildParent")
ancestors TermAncestry[] @relation("DescendantToAncestor")
descendants TermAncestry[] @relation("AncestorToDescendant")
domainId String? @map("domain_id")
domain Department? @relation("TermDom", fields: [domainId], references: [id])
createdAt DateTime @default(now()) @map("created_at")
updatedAt DateTime @updatedAt @map("updated_at")
deletedAt DateTime? @map("deleted_at")
createdBy String? @map("created_by")
depts Department[] @relation("department_term")
hasChildren Boolean? @default(false) @map("has_children")
2025-02-21 13:20:15 +08:00
posts Post[] @relation("post_term")
2025-04-21 15:46:52 +08:00
Plan Plan? @relation(fields: [planId], references: [id])
planId String?
Subject Subject? @relation(fields: [subjectId], references: [id])
subjectId String?
2025-02-21 13:20:15 +08:00
2024-12-30 08:26:40 +08:00
@@index([name]) // 对name字段建立索引以加快基于name的查找速度
@@index([parentId]) // 对parentId字段建立索引以加快基于parentId的查找速度
@@map("term")
2024-09-03 20:19:33 +08:00
}
model TermAncestry {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
ancestorId String? @map("ancestor_id")
descendantId String @map("descendant_id")
relDepth Int @map("rel_depth")
ancestor Term? @relation("AncestorToDescendant", fields: [ancestorId], references: [id])
descendant Term @relation("DescendantToAncestor", fields: [descendantId], references: [id])
2024-09-03 20:19:33 +08:00
2024-12-30 08:26:40 +08:00
// 索引建议
@@index([ancestorId]) // 针对祖先的查询
@@index([descendantId]) // 针对后代的查询
@@index([ancestorId, descendantId]) // 组合索引,用于查询特定的祖先-后代关系
@@index([relDepth]) // 根据关系深度的查询
@@map("term_ancestry")
2024-09-03 20:19:33 +08:00
}
model DeptAncestry {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
ancestorId String? @map("ancestor_id")
descendantId String @map("descendant_id")
relDepth Int @map("rel_depth")
ancestor Department? @relation("AncestorToDescendant", fields: [ancestorId], references: [id])
descendant Department @relation("DescendantToAncestor", fields: [descendantId], references: [id])
// 索引建议
@@index([ancestorId]) // 针对祖先的查询
@@index([descendantId]) // 针对后代的查询
@@index([ancestorId, descendantId]) // 组合索引,用于查询特定的祖先-后代关系
@@index([relDepth]) // 根据关系深度的查询
@@map("dept_ancestry")
2024-09-03 20:19:33 +08:00
}
model RoleMap {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
objectId String @map("object_id")
roleId String @map("role_id")
domainId String? @map("domain_id")
objectType String @map("object_type")
role Role @relation(fields: [roleId], references: [id])
@@index([domainId])
@@index([objectId])
@@map("rolemap")
2024-09-03 20:19:33 +08:00
}
model Role {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
name String @unique @map("name")
permissions String[] @default([]) @map("permissions")
roleMaps RoleMap[]
system Boolean? @default(false) @map("system")
createdAt DateTime @default(now()) @map("created_at")
updatedAt DateTime @updatedAt @map("updated_at")
deletedAt DateTime? @map("deleted_at")
@@map("role")
}
model AppConfig {
2024-12-30 13:44:30 +08:00
id String @id @default(cuid())
2024-12-30 08:26:40 +08:00
slug String @unique
title String?
description String?
meta Json?
@@map("app_config")
}
2024-12-30 13:44:30 +08:00
model Resource {
2025-01-06 18:30:16 +08:00
id String @id @default(cuid()) @map("id")
title String? @map("title")
description String? @map("description")
type String? @map("type")
fileId String? @unique
url String?
2025-01-03 09:24:46 +08:00
// 元数据
2025-02-21 13:20:15 +08:00
meta Json? @map("meta")
2025-01-03 09:24:46 +08:00
// 处理状态控制
2025-01-06 18:30:16 +08:00
status String?
createdAt DateTime? @default(now()) @map("created_at")
updatedAt DateTime? @updatedAt @map("updated_at")
createdBy String? @map("created_by")
updatedBy String? @map("updated_by")
deletedAt DateTime? @map("deleted_at")
isPublic Boolean? @default(true) @map("is_public")
2025-01-21 19:48:54 +08:00
owner Staff? @relation(fields: [ownerId], references: [id])
ownerId String? @map("owner_id")
post Post? @relation(fields: [postId], references: [id])
postId String? @map("post_id")
2025-02-21 13:20:15 +08:00
2025-01-03 09:24:46 +08:00
// 索引
2024-12-31 15:57:32 +08:00
@@index([type])
2025-01-03 09:24:46 +08:00
@@index([createdAt])
2024-12-31 15:57:32 +08:00
@@map("resource")
2024-12-30 13:44:30 +08:00
}
2025-03-11 16:15:05 +08:00
model Department {
id String @id @default(cuid())
name String
order Float?
posts Post[] @relation("post_dept")
ancestors DeptAncestry[] @relation("DescendantToAncestor")
descendants DeptAncestry[] @relation("AncestorToDescendant")
2025-03-10 20:31:05 +08:00
parentId String? @map("parent_id")
2025-03-11 16:15:05 +08:00
parent Department? @relation("ChildParent", fields: [parentId], references: [id])
children Department[] @relation("ChildParent")
domainId String? @map("domain_id")
domainTerms Term[] @relation("TermDom")
deletedAt DateTime? @map("deleted_at")
isDomain Boolean? @default(false) @map("is_domain")
domainStaffs Staff[] @relation("DomainStaff")
deptStaffs Staff[] @relation("DeptStaff")
terms Term[] @relation("department_term")
2025-03-10 20:31:05 +08:00
2025-03-12 19:38:28 +08:00
trainPlans TrainPlan[] @relation("TrainPlanDept")
2025-03-11 16:15:05 +08:00
// watchedPost Post[] @relation("post_watch_dept")
hasChildren Boolean? @default(false) @map("has_children")
2025-03-10 20:31:05 +08:00
2025-04-21 15:46:52 +08:00
planId String?
Plan Plan? @relation(fields: [planId], references: [id])
2025-03-11 16:15:05 +08:00
@@index([parentId])
@@index([isDomain])
@@index([name])
@@index([order])
@@map("department")
}
model Staff {
id String @id @default(cuid())
showname String? @map("showname")
username String @unique @map("username")
avatar String? @map("avatar")
password String? @map("password")
phoneNumber String? @unique @map("phone_number")
2025-03-27 08:50:22 +08:00
age Int? @default(22) @map("age")
sex Boolean? @default(true) @map("sex")
absent Boolean? @default(false) @map("absent")
2025-03-11 16:15:05 +08:00
trainSituations TrainSituation[]
2025-03-11 16:21:21 +08:00
position Position? @relation("StaffPosition", fields: [positionId], references: [id])
positionId String? @map("position_id")
2025-03-11 16:15:05 +08:00
domainId String? @map("domain_id")
deptId String? @map("dept_id")
domain Department? @relation("DomainStaff", fields: [domainId], references: [id])
department Department? @relation("DeptStaff", fields: [deptId], references: [id])
order Float?
2025-03-10 20:31:05 +08:00
createdAt DateTime @default(now()) @map("created_at")
updatedAt DateTime @updatedAt @map("updated_at")
2025-03-11 16:15:05 +08:00
enabled Boolean? @default(true)
deletedAt DateTime? @map("deleted_at")
officerId String? @map("officer_id")
2025-03-10 20:31:05 +08:00
2025-03-11 16:15:05 +08:00
// watchedPost Post[] @relation("post_watch_staff")
visits Visit[]
posts Post[]
learningPosts Post[] @relation("post_student")
sentMsgs Message[] @relation("message_sender")
receivedMsgs Message[] @relation("message_receiver")
registerToken String?
enrollments Enrollment[]
teachedPosts PostInstructor[]
ownedResources Resource[]
2025-04-21 15:46:52 +08:00
Plan Plan[]
2025-03-11 16:15:05 +08:00
@@index([officerId])
@@index([deptId])
@@index([domainId])
@@index([username])
@@index([order])
@@map("staff")
2025-03-11 16:21:21 +08:00
}
2025-03-12 16:34:43 +08:00
2025-04-21 15:46:52 +08:00
model Plan {
id String @id @default(cuid())
authorId String? @map("author_id")
author Staff? @relation(fields: [authorId], references: [id]) // 帖子作者,关联 Staff 模型
createdAt DateTime @default(now()) @map("created_at")
publishedAt DateTime? @map("published_at") // 发布时间
updatedAt DateTime @map("updated_at")
deletedAt DateTime? @map("deleted_at") // 删除时间,可为空
terms Term[] @relation("plan_term")
month DateTime @map("month")
week DateTime @map("week")
checked Boolean @default(false) @map("checked")
depts Department[] @relation("plan_dept")
meta Json? @map("meta") // 计划表
@@map("plan")
}
model Subject {
id String @id @default(cuid())
name String @map("name")
terms Term[] @relation("subject_term")
parentId String? @map("parent_id")
parent Subject? @relation("SubjectChildren", fields: [parentId], references: [id]) // 父级帖子,关联 Post 模型
children Subject[] @relation("SubjectChildren") // 子级帖子列表,关联 Post 模型
ancestors SubjectAncestry[] @relation("DescendantToAncestor")
descendants SubjectAncestry[] @relation("AncestorToDescendant")
@@map("subject")
}
model SubjectAncestry {
id String @id @default(cuid())
relDepth Int @map("rel_depth")
ancestorId String? @map("ancestor_id")
ancestor Subject? @relation("DescendantToAncestor", fields: [ancestorId], references: [id])
descendantId String @map("descendant_id")
descendant Subject @relation("AncestorToDescendant", fields: [descendantId], references: [id])
@@index([ancestorId])
@@index([descendantId])
@@index([ancestorId, descendantId])
@@map("subject_ancestry")
}