2022-01-08 12:29:22 +00:00
|
|
|
-- +micrate Up
|
|
|
|
-- SQL in section 'Up' is executed when this migration is applied
|
2022-02-06 15:42:08 +00:00
|
|
|
CREATE TYPE user_roles AS ENUM ('Teacher', 'Student');
|
2022-02-05 13:40:51 +00:00
|
|
|
|
|
|
|
CREATE TABLE users(
|
|
|
|
id BIGSERIAL PRIMARY KEY,
|
2022-02-06 15:42:08 +00:00
|
|
|
username TEXT UNIQUE NOT NULL,
|
2022-02-05 13:40:51 +00:00
|
|
|
role user_roles NOT NULL,
|
2022-02-06 15:42:08 +00:00
|
|
|
admin BOOLEAN NOT NULL
|
2022-01-08 12:29:22 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE teachers(
|
|
|
|
id BIGSERIAL PRIMARY KEY,
|
|
|
|
user_id BIGINT NOT NULL UNIQUE REFERENCES users(id),
|
2022-01-20 16:30:20 +00:00
|
|
|
max_students INT NOT NULL,
|
|
|
|
skif BOOLEAN NOT NULL
|
2022-01-08 12:29:22 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE students(
|
|
|
|
id BIGSERIAL PRIMARY KEY,
|
|
|
|
user_id BIGINT NOT NULL UNIQUE REFERENCES users(id),
|
|
|
|
skif BOOLEAN NOT NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
ALTER TABLE
|
|
|
|
users
|
|
|
|
ADD
|
|
|
|
COLUMN teacher_id BIGINT UNIQUE REFERENCES teachers(id);
|
|
|
|
|
|
|
|
ALTER TABLE
|
|
|
|
users
|
|
|
|
ADD
|
|
|
|
COLUMN student_id BIGINT UNIQUE REFERENCES students(id);
|
|
|
|
|
2022-02-05 13:40:51 +00:00
|
|
|
CREATE TABLE votes(
|
|
|
|
id BIGSERIAL PRIMARY KEY,
|
|
|
|
student_id BIGINT NOT NULL UNIQUE REFERENCES students(id)
|
|
|
|
);
|
2022-01-08 12:29:22 +00:00
|
|
|
|
2022-01-20 16:30:20 +00:00
|
|
|
ALTER TABLE
|
2022-02-05 13:40:51 +00:00
|
|
|
students
|
|
|
|
ADD
|
|
|
|
COLUMN vote_id BIGINT UNIQUE REFERENCES votes(id);
|
2022-01-08 12:29:22 +00:00
|
|
|
|
2022-02-05 13:40:51 +00:00
|
|
|
CREATE TABLE teacher_votes(
|
|
|
|
id BIGSERIAL PRIMARY KEY,
|
|
|
|
vote_id BIGINT NOT NULL REFERENCES votes(id),
|
|
|
|
teacher_id BIGINT NOT NULL REFERENCES teachers(id),
|
|
|
|
priority INT NOT NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
-- +micrate Down
|
|
|
|
-- SQL section 'Down' is executed when this migration is rolled back
|
|
|
|
DROP TABLE teacher_votes;
|
|
|
|
|
|
|
|
DROP TABLE votes;
|
2022-01-08 12:29:22 +00:00
|
|
|
|
|
|
|
DROP TABLE admins;
|
|
|
|
|
|
|
|
DROP TABLE teachers;
|
|
|
|
|
2022-02-05 13:40:51 +00:00
|
|
|
DROP TABLE students;
|
|
|
|
|
|
|
|
DROP TABLE users;
|
|
|
|
|
|
|
|
DROP TYPE user_roles;
|