just_for_fun/code/python/db_connect/sql/db.sql
2025-05-19 13:04:38 +03:00

69 lines
2.1 KiB
SQL

CREATE TABLE "account" (
"id" SERIAL PRIMARY KEY,
"login" VARCHAR(10) NOT NULL,
"pswd" VARCHAR(255) NOT NULL,
"is_block" BOOLEAN,
"dt_create" DATE,
"token" VARCHAR(255) NOT NULL,
"refresh" VARCHAR(255) NOT NULL
);
CREATE TABLE "profile" (
"id" SERIAL PRIMARY KEY,
"id_account" INTEGER NOT NULL,
"name" VARCHAR(100) NOT NULL,
"surname" VARCHAR(100) NOT NULL,
"sex" BOOLEAN,
"dt_birth" TIMESTAMP
);
CREATE INDEX "idx_profile__id_account" ON "profile" ("id_account");
ALTER TABLE "profile" ADD CONSTRAINT "fk_profile__id_account" FOREIGN KEY ("id_account") REFERENCES "account" ("id");
CREATE TABLE "role" (
"id" SERIAL PRIMARY KEY,
"name" TEXT NOT NULL
);
CREATE TABLE "role_account" (
"id_roles" INTEGER NOT NULL,
"acconts" INTEGER NOT NULL,
PRIMARY KEY ("id_roles", "acconts")
);
CREATE INDEX "idx_role_account__acconts" ON "role_account" ("acconts");
ALTER TABLE "role_account" ADD CONSTRAINT "fk_role_account__acconts" FOREIGN KEY ("acconts") REFERENCES "account" ("id") ON DELETE CASCADE;
ALTER TABLE "role_account" ADD CONSTRAINT "fk_role_account__id_roles" FOREIGN KEY ("id_roles") REFERENCES "role" ("id") ON DELETE CASCADE;
CREATE TABLE "rules" (
"id" SERIAL PRIMARY KEY,
"name" TEXT NOT NULL,
"body" JSONB NOT NULL
);
CREATE TABLE "role_rules" (
"id_roles" INTEGER NOT NULL,
"id_rules" INTEGER NOT NULL,
PRIMARY KEY ("id_roles", "id_rules")
);
CREATE INDEX "idx_role_rules__id_rules" ON "role_rules" ("id_rules");
ALTER TABLE "role_rules" ADD CONSTRAINT "fk_role_rules__id_roles" FOREIGN KEY ("id_roles") REFERENCES "role" ("id") ON DELETE CASCADE;
ALTER TABLE "role_rules" ADD CONSTRAINT "fk_role_rules__id_rules" FOREIGN KEY ("id_rules") REFERENCES "rules" ("id") ON DELETE CASCADE;
CREATE TABLE "rules_rules" (
"rules" INTEGER NOT NULL,
"rules_2" INTEGER NOT NULL,
PRIMARY KEY ("rules", "rules_2")
);
CREATE INDEX "idx_rules_rules" ON "rules_rules" ("rules_2");
ALTER TABLE "rules_rules" ADD CONSTRAINT "fk_rules_rules__rules" FOREIGN KEY ("rules") REFERENCES "rules" ("id");
ALTER TABLE "rules_rules" ADD CONSTRAINT "fk_rules_rules__rules_2" FOREIGN KEY ("rules_2") REFERENCES "rules" ("id")