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