X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=db.sql;h=696cec175e2f0a3d5d7574dae80cee94cc271897;hb=adb42d4d148fdb3dd145e4a7452b7b7eda88f66c;hp=1556202076909318c6718fc10d3189caeac78a28;hpb=8bd66733a4d66baf38f69ea36154d1873ad5edba;p=gruntmaster-data.git diff --git a/db.sql b/db.sql index 1556202..696cec1 100644 --- a/db.sql +++ b/db.sql @@ -20,6 +20,15 @@ CREATE TABLE contests ( CONSTRAINT positive_duration CHECK (stop > start) ); +CREATE TABLE contest_status ( + contest TEXT NOT NULL REFERENCES contests ON DELETE CASCADE, + owner TEXT NOT NULL REFERENCES users ON DELETE CASCADE, + score INT NOT NULL, + rank INT NOT NULL, + + PRIMARY KEY (owner, contest) +); + CREATE TABLE problems ( id TEXT PRIMARY KEY, author TEXT, @@ -67,6 +76,15 @@ CREATE TABLE jobs ( owner TEXT NOT NULL REFERENCES users ON DELETE CASCADE ); +CREATE TABLE problem_status ( + problem TEXT NOT NULL REFERENCES problems ON DELETE CASCADE, + owner TEXT NOT NULL REFERENCES users ON DELETE CASCADE, + job SERIAL NOT NULL REFERENCES jobs ON DELETE CASCADE, + solved BOOLEAN NOT NULL DEFAULT FALSE, + + PRIMARY KEY (owner, problem) +); + CREATE TABLE opens ( contest TEXT NOT NULL REFERENCES contests ON DELETE CASCADE, problem TEXT NOT NULL REFERENCES problems ON DELETE CASCADE,