- Add Prisma migrations for batch processing tables - Add Prisma migrations for review tasks tables - Add seed data for testing - Add prompt templates for review (editorial, methodology) - Add CloseAI configuration guide - Add database validation scripts
152 lines
5.1 KiB
SQL
152 lines
5.1 KiB
SQL
-- AlterTable
|
|
ALTER TABLE "documents" ADD COLUMN "char_count" INTEGER,
|
|
ADD COLUMN "extracted_text" TEXT,
|
|
ADD COLUMN "extraction_method" TEXT,
|
|
ADD COLUMN "extraction_quality" DOUBLE PRECISION,
|
|
ADD COLUMN "language" TEXT;
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "batch_tasks" (
|
|
"id" TEXT NOT NULL,
|
|
"user_id" TEXT NOT NULL,
|
|
"kb_id" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"template_type" TEXT NOT NULL,
|
|
"template_id" TEXT,
|
|
"prompt" TEXT NOT NULL,
|
|
"status" TEXT NOT NULL,
|
|
"total_documents" INTEGER NOT NULL,
|
|
"completed_count" INTEGER NOT NULL DEFAULT 0,
|
|
"failed_count" INTEGER NOT NULL DEFAULT 0,
|
|
"model_type" TEXT NOT NULL,
|
|
"concurrency" INTEGER NOT NULL DEFAULT 3,
|
|
"started_at" TIMESTAMP(3),
|
|
"completed_at" TIMESTAMP(3),
|
|
"duration_seconds" INTEGER,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "batch_tasks_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "batch_results" (
|
|
"id" TEXT NOT NULL,
|
|
"task_id" TEXT NOT NULL,
|
|
"document_id" TEXT NOT NULL,
|
|
"status" TEXT NOT NULL,
|
|
"data" JSONB,
|
|
"rawOutput" TEXT,
|
|
"error_message" TEXT,
|
|
"processing_time_ms" INTEGER,
|
|
"tokens_used" INTEGER,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "batch_results_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "task_templates" (
|
|
"id" TEXT NOT NULL,
|
|
"user_id" TEXT NOT NULL,
|
|
"name" TEXT NOT NULL,
|
|
"description" TEXT,
|
|
"prompt" TEXT NOT NULL,
|
|
"outputFields" JSONB NOT NULL,
|
|
"is_public" BOOLEAN NOT NULL DEFAULT false,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "task_templates_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "general_conversations" (
|
|
"id" TEXT NOT NULL,
|
|
"user_id" TEXT NOT NULL,
|
|
"title" TEXT NOT NULL,
|
|
"model_name" TEXT,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"deleted_at" TIMESTAMP(3),
|
|
|
|
CONSTRAINT "general_conversations_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "general_messages" (
|
|
"id" TEXT NOT NULL,
|
|
"conversation_id" TEXT NOT NULL,
|
|
"role" TEXT NOT NULL,
|
|
"content" TEXT NOT NULL,
|
|
"model" TEXT,
|
|
"metadata" JSONB,
|
|
"tokens" INTEGER,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "general_messages_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_tasks_user_id_idx" ON "batch_tasks"("user_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_tasks_kb_id_idx" ON "batch_tasks"("kb_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_tasks_status_idx" ON "batch_tasks"("status");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_tasks_created_at_idx" ON "batch_tasks"("created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_results_task_id_idx" ON "batch_results"("task_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_results_document_id_idx" ON "batch_results"("document_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "batch_results_status_idx" ON "batch_results"("status");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "task_templates_user_id_idx" ON "task_templates"("user_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "general_conversations_user_id_idx" ON "general_conversations"("user_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "general_conversations_created_at_idx" ON "general_conversations"("created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "general_conversations_updated_at_idx" ON "general_conversations"("updated_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "general_messages_conversation_id_idx" ON "general_messages"("conversation_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "general_messages_created_at_idx" ON "general_messages"("created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "documents_extraction_method_idx" ON "documents"("extraction_method");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "batch_tasks" ADD CONSTRAINT "batch_tasks_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "batch_tasks" ADD CONSTRAINT "batch_tasks_kb_id_fkey" FOREIGN KEY ("kb_id") REFERENCES "knowledge_bases"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "batch_results" ADD CONSTRAINT "batch_results_task_id_fkey" FOREIGN KEY ("task_id") REFERENCES "batch_tasks"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "batch_results" ADD CONSTRAINT "batch_results_document_id_fkey" FOREIGN KEY ("document_id") REFERENCES "documents"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "task_templates" ADD CONSTRAINT "task_templates_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "general_conversations" ADD CONSTRAINT "general_conversations_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "general_messages" ADD CONSTRAINT "general_messages_conversation_id_fkey" FOREIGN KEY ("conversation_id") REFERENCES "general_conversations"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|