]> git.sesse.net Git - ccbs/blob - ccbs.sql
64b79427113c60d46260ee7a29c22433aa317dad
[ccbs] / ccbs.sql
1 -- vim:set tw=0:
2
3 CREATE TABLE machines (
4         machine SERIAL PRIMARY KEY,
5         name VARCHAR NOT NULL
6 );
7
8 CREATE TABLE countries (
9         country SERIAL PRIMARY KEY,
10         name VARCHAR NOT NULL
11 );
12
13 CREATE TABLE songs (
14         song SERIAL PRIMARY KEY,
15         title VARCHAR NOT NULL,
16         artist VARCHAR NOT NULL
17 );
18
19 -- CREATE TABLE machinesongs etc.
20
21 CREATE TABLE scoringsystems (
22         scoringsystem SERIAL PRIMARY KEY,
23         name VARCHAR NOT NULL
24 );
25
26 CREATE TABLE songratings (
27         song INTEGER NOT NULL REFERENCES songs,   -- strictly song+machine
28         playmode VARCHAR NOT NULL CHECK (playmode IN ('single','double')),
29         difficulty VARCHAR NOT NULL CHECK (difficulty IN ('beginner','standard','difficult','expert','challenge')),
30         feetrating INTEGER NOT NULL CHECK (feetrating >= 0 AND feetrating <= 10),
31
32         PRIMARY KEY (song, playmode, difficulty)
33 );
34
35 CREATE TABLE players (
36         player SERIAL PRIMARY KEY,
37         nick VARCHAR NOT NULL
38 );
39
40 CREATE TABLE seasons (
41         season SERIAL PRIMARY KEY,
42         name VARCHAR NOT NULL
43 );
44
45 CREATE TABLE tournaments (
46         tournament SERIAL PRIMARY KEY,
47         season INTEGER NOT NULL REFERENCES seasons,
48         name VARCHAR NOT NULL,
49         country INTEGER NOT NULL REFERENCES countries,
50         location VARCHAR NOT NULL,
51         "date" DATE NOT NULL,
52         machine INTEGER NOT NULL REFERENCES machines,
53         scoringsystem INTEGER NOT NULL REFERENCES scoringsystems
54 );
55
56 CREATE TABLE rounds (
57         tournament INTEGER NOT NULL REFERENCES tournaments,
58         round INTEGER NOT NULL,
59         randomsongs INTEGER NOT NULL,
60         chosensongs INTEGER NOT NULL,
61
62         PRIMARY KEY (tournament, round)
63 );
64
65 CREATE TABLE groups (
66         tournament INTEGER NOT NULL REFERENCES tournaments,
67         round INTEGER NOT NULL,
68         parallel INTEGER NOT NULL,
69
70         FOREIGN KEY (tournament, round) REFERENCES rounds (tournament, round),
71         PRIMARY KEY (tournament, round, parallel)
72 );
73
74 CREATE TABLE roundrandomsongs (
75         tournament INTEGER NOT NULL,
76         round INTEGER NOT NULL,
77         parallel INTEGER NOT NULL,
78         song INTEGER NOT NULL REFERENCES songs,
79
80         FOREIGN KEY (tournament, round, parallel) REFERENCES groups (tournament, round, parallel),
81         PRIMARY KEY (tournament, round, parallel, song)
82 );
83
84 CREATE TABLE roundparticipation (
85         tournament INTEGER NOT NULL,
86         round INTEGER NOT NULL,
87         parallel INTEGER NOT NULL,
88         player INTEGER NOT NULL REFERENCES players,
89
90         UNIQUE (tournament, round, player),
91         FOREIGN KEY (tournament, round, parallel) REFERENCES groups (tournament, round, parallel),
92         PRIMARY KEY (tournament, round, parallel, player)
93 );
94
95 CREATE TABLE scores (
96         tournament INTEGER NOT NULL,
97         round INTEGER NOT NULL,
98         parallel INTEGER NOT NULL,
99         player INTEGER NOT NULL REFERENCES players,
100         
101         song INTEGER NOT NULL REFERENCES songs,
102         playmode VARCHAR CHECK (playmode IS NULL OR playmode IN ('single','double')),
103         difficulty VARCHAR CHECK (difficulty IS NULL OR difficulty IN ('beginner','standard','difficult','expert','challenge')),
104         
105         chosen BOOLEAN NOT NULL,
106         score INTEGER NOT NULL CHECK (score >= 0 AND score <= 10000),
107         
108         FOREIGN KEY (song) REFERENCES songs (song),
109         FOREIGN KEY (song, playmode, difficulty) REFERENCES songratings (song, playmode, difficulty),
110         FOREIGN KEY (tournament, round, parallel, player) REFERENCES roundparticipation (tournament, round, parallel, player),
111         PRIMARY KEY (tournament, round, parallel, player, song)
112 );