diff options
| author | nsfisis <nsfisis@gmail.com> | 2025-12-06 17:05:21 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2025-12-06 17:37:04 +0900 |
| commit | 811458427593a4172a2cd535cc768db375350dca (patch) | |
| tree | 6c4f46c96b6f29392dc19d591e39e03c187033a1 /drizzle/0000_cynical_zeigeist.sql | |
| parent | 9736a8981fbd6c6defbd67517ca23904fc844629 (diff) | |
| download | kioku-811458427593a4172a2cd535cc768db375350dca.tar.gz kioku-811458427593a4172a2cd535cc768db375350dca.tar.zst kioku-811458427593a4172a2cd535cc768db375350dca.zip | |
feat(dev): change architecture and directory structure
Diffstat (limited to 'drizzle/0000_cynical_zeigeist.sql')
| -rw-r--r-- | drizzle/0000_cynical_zeigeist.sql | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/drizzle/0000_cynical_zeigeist.sql b/drizzle/0000_cynical_zeigeist.sql new file mode 100644 index 0000000..3034102 --- /dev/null +++ b/drizzle/0000_cynical_zeigeist.sql @@ -0,0 +1,58 @@ +CREATE TABLE "cards" ( + "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, + "deck_id" uuid NOT NULL, + "front" text NOT NULL, + "back" text NOT NULL, + "state" smallint DEFAULT 0 NOT NULL, + "due" timestamp with time zone DEFAULT now() NOT NULL, + "stability" real DEFAULT 0 NOT NULL, + "difficulty" real DEFAULT 0 NOT NULL, + "elapsed_days" integer DEFAULT 0 NOT NULL, + "scheduled_days" integer DEFAULT 0 NOT NULL, + "reps" integer DEFAULT 0 NOT NULL, + "lapses" integer DEFAULT 0 NOT NULL, + "last_review" timestamp with time zone, + "created_at" timestamp with time zone DEFAULT now() NOT NULL, + "updated_at" timestamp with time zone DEFAULT now() NOT NULL, + "deleted_at" timestamp with time zone, + "sync_version" integer DEFAULT 0 NOT NULL +); +--> statement-breakpoint +CREATE TABLE "decks" ( + "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, + "user_id" uuid NOT NULL, + "name" varchar(255) NOT NULL, + "description" text, + "new_cards_per_day" integer DEFAULT 20 NOT NULL, + "created_at" timestamp with time zone DEFAULT now() NOT NULL, + "updated_at" timestamp with time zone DEFAULT now() NOT NULL, + "deleted_at" timestamp with time zone, + "sync_version" integer DEFAULT 0 NOT NULL +); +--> statement-breakpoint +CREATE TABLE "review_logs" ( + "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, + "card_id" uuid NOT NULL, + "user_id" uuid NOT NULL, + "rating" smallint NOT NULL, + "state" smallint NOT NULL, + "scheduled_days" integer NOT NULL, + "elapsed_days" integer NOT NULL, + "reviewed_at" timestamp with time zone DEFAULT now() NOT NULL, + "duration_ms" integer, + "sync_version" integer DEFAULT 0 NOT NULL +); +--> statement-breakpoint +CREATE TABLE "users" ( + "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, + "username" varchar(255) NOT NULL, + "password_hash" varchar(255) NOT NULL, + "created_at" timestamp with time zone DEFAULT now() NOT NULL, + "updated_at" timestamp with time zone DEFAULT now() NOT NULL, + CONSTRAINT "users_username_unique" UNIQUE("username") +); +--> statement-breakpoint +ALTER TABLE "cards" ADD CONSTRAINT "cards_deck_id_decks_id_fk" FOREIGN KEY ("deck_id") REFERENCES "public"."decks"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint +ALTER TABLE "decks" ADD CONSTRAINT "decks_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint +ALTER TABLE "review_logs" ADD CONSTRAINT "review_logs_card_id_cards_id_fk" FOREIGN KEY ("card_id") REFERENCES "public"."cards"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint +ALTER TABLE "review_logs" ADD CONSTRAINT "review_logs_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;
\ No newline at end of file |
