263 lines
9.8 KiB
SQL
263 lines
9.8 KiB
SQL
-- CreateTable
|
|
CREATE TABLE "tenants" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"name" TEXT NOT NULL,
|
|
"address" TEXT,
|
|
"contact_person" TEXT,
|
|
"contact_phone" TEXT,
|
|
"logo_url" TEXT,
|
|
"package_type" TEXT NOT NULL DEFAULT 'STANDARD',
|
|
"teacher_quota" INTEGER NOT NULL DEFAULT 20,
|
|
"student_quota" INTEGER NOT NULL DEFAULT 200,
|
|
"storage_quota" BIGINT NOT NULL DEFAULT 5368709120,
|
|
"start_date" TEXT NOT NULL,
|
|
"expire_date" TEXT NOT NULL,
|
|
"teacher_count" INTEGER NOT NULL DEFAULT 0,
|
|
"student_count" INTEGER NOT NULL DEFAULT 0,
|
|
"storage_used" BIGINT NOT NULL DEFAULT 0,
|
|
"status" TEXT NOT NULL DEFAULT 'ACTIVE',
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "teachers" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"tenant_id" BIGINT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"phone" TEXT NOT NULL,
|
|
"email" TEXT,
|
|
"login_account" TEXT NOT NULL,
|
|
"password_hash" TEXT NOT NULL,
|
|
"class_ids" TEXT DEFAULT '[]',
|
|
"status" TEXT NOT NULL DEFAULT 'ACTIVE',
|
|
"lesson_count" INTEGER NOT NULL DEFAULT 0,
|
|
"feedback_count" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
"last_login_at" DATETIME,
|
|
CONSTRAINT "teachers_tenant_id_fkey" FOREIGN KEY ("tenant_id") REFERENCES "tenants" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "classes" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"tenant_id" BIGINT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"grade" TEXT NOT NULL,
|
|
"teacher_id" BIGINT,
|
|
"student_count" INTEGER NOT NULL DEFAULT 0,
|
|
"lesson_count" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "classes_tenant_id_fkey" FOREIGN KEY ("tenant_id") REFERENCES "tenants" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "classes_teacher_id_fkey" FOREIGN KEY ("teacher_id") REFERENCES "teachers" ("id") ON DELETE SET NULL ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "students" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"tenant_id" BIGINT NOT NULL,
|
|
"class_id" BIGINT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"gender" TEXT,
|
|
"birth_date" DATETIME,
|
|
"parent_phone" TEXT,
|
|
"parent_name" TEXT,
|
|
"reading_count" INTEGER NOT NULL DEFAULT 0,
|
|
"lesson_count" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "students_tenant_id_fkey" FOREIGN KEY ("tenant_id") REFERENCES "tenants" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "students_class_id_fkey" FOREIGN KEY ("class_id") REFERENCES "classes" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "courses" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"name" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"picture_book_id" INTEGER,
|
|
"picture_book_name" TEXT,
|
|
"grade_tags" TEXT NOT NULL DEFAULT '[]',
|
|
"domain_tags" TEXT NOT NULL DEFAULT '[]',
|
|
"duration" INTEGER NOT NULL DEFAULT 25,
|
|
"status" TEXT NOT NULL DEFAULT 'DRAFT',
|
|
"version" TEXT NOT NULL DEFAULT '1.0',
|
|
"usage_count" INTEGER NOT NULL DEFAULT 0,
|
|
"teacher_count" INTEGER NOT NULL DEFAULT 0,
|
|
"avg_rating" REAL NOT NULL DEFAULT 0,
|
|
"created_by" INTEGER,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
"published_at" DATETIME
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "course_resources" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"course_id" BIGINT NOT NULL,
|
|
"resource_type" TEXT NOT NULL,
|
|
"resource_name" TEXT NOT NULL,
|
|
"file_url" TEXT NOT NULL,
|
|
"file_size" BIGINT,
|
|
"mime_type" TEXT,
|
|
"metadata" TEXT,
|
|
"sort_order" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
CONSTRAINT "course_resources_course_id_fkey" FOREIGN KEY ("course_id") REFERENCES "courses" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "course_scripts" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"course_id" BIGINT NOT NULL,
|
|
"step_index" INTEGER NOT NULL,
|
|
"step_name" TEXT NOT NULL,
|
|
"step_type" TEXT NOT NULL,
|
|
"duration" INTEGER NOT NULL,
|
|
"objective" TEXT,
|
|
"teacher_script" TEXT,
|
|
"interaction_points" TEXT,
|
|
"resource_ids" TEXT,
|
|
"sort_order" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "course_scripts_course_id_fkey" FOREIGN KEY ("course_id") REFERENCES "courses" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "course_script_pages" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"script_id" BIGINT NOT NULL,
|
|
"page_number" INTEGER NOT NULL,
|
|
"questions" TEXT,
|
|
"interaction_component" TEXT,
|
|
"teacher_notes" TEXT,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "course_script_pages_script_id_fkey" FOREIGN KEY ("script_id") REFERENCES "course_scripts" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "course_activities" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"course_id" BIGINT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"domain" TEXT,
|
|
"domain_tag_id" INTEGER,
|
|
"activity_type" TEXT NOT NULL,
|
|
"duration" INTEGER,
|
|
"online_materials" TEXT,
|
|
"offlineMaterials" TEXT,
|
|
"activityGuide" TEXT,
|
|
"objectives" TEXT,
|
|
"sort_order" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
CONSTRAINT "course_activities_course_id_fkey" FOREIGN KEY ("course_id") REFERENCES "courses" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "lessons" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"tenant_id" BIGINT NOT NULL,
|
|
"teacher_id" BIGINT NOT NULL,
|
|
"class_id" BIGINT NOT NULL,
|
|
"course_id" BIGINT NOT NULL,
|
|
"planned_datetime" DATETIME,
|
|
"start_datetime" DATETIME,
|
|
"end_datetime" DATETIME,
|
|
"actual_duration" INTEGER,
|
|
"status" TEXT NOT NULL DEFAULT 'PLANNED',
|
|
"overall_rating" TEXT,
|
|
"participation_rating" TEXT,
|
|
"completion_note" TEXT,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "lessons_tenant_id_fkey" FOREIGN KEY ("tenant_id") REFERENCES "tenants" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "lessons_teacher_id_fkey" FOREIGN KEY ("teacher_id") REFERENCES "teachers" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "lessons_class_id_fkey" FOREIGN KEY ("class_id") REFERENCES "classes" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "lessons_course_id_fkey" FOREIGN KEY ("course_id") REFERENCES "courses" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "lesson_feedbacks" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"lesson_id" BIGINT NOT NULL,
|
|
"teacher_id" BIGINT NOT NULL,
|
|
"design_quality" INTEGER,
|
|
"participation" INTEGER,
|
|
"goal_achievement" INTEGER,
|
|
"step_feedbacks" TEXT,
|
|
"pros" TEXT,
|
|
"suggestions" TEXT,
|
|
"activities_done" TEXT,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "lesson_feedbacks_lesson_id_fkey" FOREIGN KEY ("lesson_id") REFERENCES "lessons" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "lesson_feedbacks_teacher_id_fkey" FOREIGN KEY ("teacher_id") REFERENCES "teachers" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "student_records" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"lesson_id" BIGINT NOT NULL,
|
|
"student_id" BIGINT NOT NULL,
|
|
"focus" INTEGER,
|
|
"participation" INTEGER,
|
|
"interest" INTEGER,
|
|
"understanding" INTEGER,
|
|
"domainAchievements" TEXT,
|
|
"notes" TEXT,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" DATETIME NOT NULL,
|
|
CONSTRAINT "student_records_lesson_id_fkey" FOREIGN KEY ("lesson_id") REFERENCES "lessons" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "student_records_student_id_fkey" FOREIGN KEY ("student_id") REFERENCES "students" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "tags" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"level" INTEGER NOT NULL,
|
|
"code" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"parent_id" BIGINT,
|
|
"description" TEXT,
|
|
"metadata" TEXT,
|
|
"sort_order" INTEGER NOT NULL DEFAULT 0,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "tenant_courses" (
|
|
"id" BIGINT NOT NULL PRIMARY KEY,
|
|
"tenant_id" BIGINT NOT NULL,
|
|
"course_id" BIGINT NOT NULL,
|
|
"authorized" BOOLEAN NOT NULL DEFAULT true,
|
|
"authorized_at" DATETIME,
|
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
CONSTRAINT "tenant_courses_tenant_id_fkey" FOREIGN KEY ("tenant_id") REFERENCES "tenants" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "tenant_courses_course_id_fkey" FOREIGN KEY ("course_id") REFERENCES "courses" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "teachers_login_account_key" ON "teachers"("login_account");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "course_scripts_course_id_step_index_key" ON "course_scripts"("course_id", "step_index");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "course_script_pages_script_id_page_number_key" ON "course_script_pages"("script_id", "page_number");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "lesson_feedbacks_lesson_id_teacher_id_key" ON "lesson_feedbacks"("lesson_id", "teacher_id");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "student_records_lesson_id_student_id_key" ON "student_records"("lesson_id", "student_id");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "tags_code_key" ON "tags"("code");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "tenant_courses_tenant_id_course_id_key" ON "tenant_courses"("tenant_id", "course_id");
|