201 lines
6.3 KiB
SQL
201 lines
6.3 KiB
SQL
-- CreateTable
|
|
CREATE TABLE "Author" (
|
|
"sec_uid" TEXT NOT NULL,
|
|
"uid" TEXT,
|
|
"nickname" TEXT NOT NULL,
|
|
"signature" TEXT,
|
|
"avatar_url" TEXT,
|
|
"follower_count" BIGINT NOT NULL DEFAULT 0,
|
|
"total_favorited" BIGINT NOT NULL DEFAULT 0,
|
|
"unique_id" TEXT,
|
|
"short_id" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Author_pkey" PRIMARY KEY ("sec_uid")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Video" (
|
|
"aweme_id" TEXT NOT NULL,
|
|
"desc" TEXT NOT NULL,
|
|
"preview_title" TEXT,
|
|
"duration_ms" INTEGER NOT NULL,
|
|
"created_at" TIMESTAMP(3) NOT NULL,
|
|
"share_url" TEXT NOT NULL,
|
|
"digg_count" BIGINT NOT NULL DEFAULT 0,
|
|
"comment_count" BIGINT NOT NULL DEFAULT 0,
|
|
"share_count" BIGINT NOT NULL DEFAULT 0,
|
|
"collect_count" BIGINT NOT NULL DEFAULT 0,
|
|
"width" INTEGER,
|
|
"height" INTEGER,
|
|
"fps" INTEGER,
|
|
"cover_url" TEXT,
|
|
"authorId" TEXT NOT NULL,
|
|
"tags" TEXT[],
|
|
"video_url" TEXT NOT NULL,
|
|
"raw_json" JSONB,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Video_pkey" PRIMARY KEY ("aweme_id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "CommentUser" (
|
|
"id" TEXT NOT NULL,
|
|
"nickname" TEXT NOT NULL,
|
|
"avatar_url" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "CommentUser_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "Comment" (
|
|
"cid" TEXT NOT NULL,
|
|
"text" TEXT NOT NULL,
|
|
"digg_count" BIGINT NOT NULL DEFAULT 0,
|
|
"created_at" TIMESTAMP(3) NOT NULL,
|
|
"videoId" TEXT,
|
|
"imagePostId" TEXT,
|
|
"userId" TEXT NOT NULL,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "Comment_pkey" PRIMARY KEY ("cid")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "CommentImage" (
|
|
"id" TEXT NOT NULL,
|
|
"commentId" TEXT NOT NULL,
|
|
"url" TEXT NOT NULL,
|
|
"order" INTEGER NOT NULL,
|
|
"width" INTEGER,
|
|
"height" INTEGER,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "CommentImage_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "ImagePost" (
|
|
"aweme_id" TEXT NOT NULL,
|
|
"desc" TEXT NOT NULL,
|
|
"created_at" TIMESTAMP(3) NOT NULL,
|
|
"share_url" TEXT NOT NULL,
|
|
"digg_count" BIGINT NOT NULL DEFAULT 0,
|
|
"comment_count" BIGINT NOT NULL DEFAULT 0,
|
|
"share_count" BIGINT NOT NULL DEFAULT 0,
|
|
"collect_count" BIGINT NOT NULL DEFAULT 0,
|
|
"authorId" TEXT NOT NULL,
|
|
"tags" TEXT[],
|
|
"music_url" TEXT,
|
|
"raw_json" JSONB,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "ImagePost_pkey" PRIMARY KEY ("aweme_id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "ImageFile" (
|
|
"id" TEXT NOT NULL,
|
|
"postId" TEXT NOT NULL,
|
|
"url" TEXT NOT NULL,
|
|
"order" INTEGER NOT NULL,
|
|
"width" INTEGER,
|
|
"height" INTEGER,
|
|
"animated" TEXT,
|
|
"duration" INTEGER,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "ImageFile_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "VideoTranscript" (
|
|
"id" TEXT NOT NULL,
|
|
"videoId" TEXT NOT NULL,
|
|
"speech_detected" BOOLEAN NOT NULL,
|
|
"language" TEXT,
|
|
"audio_type" TEXT,
|
|
"transcript" TEXT[],
|
|
"non_speech_summary" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "VideoTranscript_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "Author_uid_key" ON "Author"("uid");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "Video_authorId_idx" ON "Video"("authorId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "Video_created_at_idx" ON "Video"("created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "CommentUser_nickname_avatar_url_key" ON "CommentUser"("nickname", "avatar_url");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "Comment_videoId_created_at_idx" ON "Comment"("videoId", "created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "Comment_imagePostId_created_at_idx" ON "Comment"("imagePostId", "created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "CommentImage_commentId_order_idx" ON "CommentImage"("commentId", "order");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "CommentImage_commentId_order_key" ON "CommentImage"("commentId", "order");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "ImagePost_authorId_idx" ON "ImagePost"("authorId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "ImagePost_created_at_idx" ON "ImagePost"("created_at");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "ImageFile_postId_order_idx" ON "ImageFile"("postId", "order");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "ImageFile_postId_order_key" ON "ImageFile"("postId", "order");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "VideoTranscript_videoId_key" ON "VideoTranscript"("videoId");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "VideoTranscript_videoId_idx" ON "VideoTranscript"("videoId");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Video" ADD CONSTRAINT "Video_authorId_fkey" FOREIGN KEY ("authorId") REFERENCES "Author"("sec_uid") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Comment" ADD CONSTRAINT "Comment_videoId_fkey" FOREIGN KEY ("videoId") REFERENCES "Video"("aweme_id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Comment" ADD CONSTRAINT "Comment_imagePostId_fkey" FOREIGN KEY ("imagePostId") REFERENCES "ImagePost"("aweme_id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "Comment" ADD CONSTRAINT "Comment_userId_fkey" FOREIGN KEY ("userId") REFERENCES "CommentUser"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "CommentImage" ADD CONSTRAINT "CommentImage_commentId_fkey" FOREIGN KEY ("commentId") REFERENCES "Comment"("cid") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "ImagePost" ADD CONSTRAINT "ImagePost_authorId_fkey" FOREIGN KEY ("authorId") REFERENCES "Author"("sec_uid") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "ImageFile" ADD CONSTRAINT "ImageFile_postId_fkey" FOREIGN KEY ("postId") REFERENCES "ImagePost"("aweme_id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "VideoTranscript" ADD CONSTRAINT "VideoTranscript_videoId_fkey" FOREIGN KEY ("videoId") REFERENCES "Video"("aweme_id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|