Add rank history to the build.
[xonotic/xonstatdb.git] / build / build_full.sql
1 -- drop tables first in reverse order
2 drop table if exists player_ranks_history cascade;
3 drop table if exists player_ranks cascade;
4 drop table if exists player_elos cascade;
5 drop table if exists player_nicks cascade;
6 drop table if exists db_version cascade;
7 drop table if exists hashkeys cascade;
8 drop table if exists player_weapon_stats cascade;
9 drop table if exists achievements cascade;
10 drop table if exists cd_achievement cascade;
11 --drop table if exists game_mutators cascade;
12 drop table if exists player_game_stats cascade;
13 drop table if exists games cascade;
14 --drop table if exists map_game_types cascade;
15 drop table if exists maps cascade;
16 drop table if exists servers cascade;
17 drop table if exists cd_game_type cascade;
18 drop table if exists cd_weapon cascade;
19 --drop table if exists cd_mutator cascade;
20 drop table if exists players cascade;
21
22 -- table definitions
23 \i tables/players.tab
24 --\i tables/cd_mutator.tab
25 \i tables/cd_game_type.tab
26 \i tables/cd_weapon.tab
27 \i tables/servers.tab
28 \i tables/maps.tab
29 --\i tables/map_game_types.tab
30 \i tables/games.tab
31 \i tables/player_game_stats.tab
32 --\i tables/game_mutators.tab
33 \i tables/cd_achievement.tab
34 \i tables/achievements.tab
35 \i tables/player_weapon_stats.tab
36 \i tables/hashkeys.tab
37 \i tables/db_version.tab
38 \i tables/player_nicks.tab
39 \i tables/player_elos.tab
40 \i tables/player_ranks.tab
41 \i tables/player_ranks_history.tab
42
43 begin;
44
45 -- game types
46 insert into cd_game_type(game_type_cd, descr)
47 values('arena', 'Arena');
48 insert into cd_game_type(game_type_cd, descr)
49 values('as', 'Assault');
50 insert into cd_game_type(game_type_cd, descr)
51 values('ctf', 'Capture The Flag');
52 insert into cd_game_type(game_type_cd, descr)
53 values('ca', 'Clan Arena');
54 insert into cd_game_type(game_type_cd, descr)
55 values('dm', 'Deathmatch');
56 insert into cd_game_type(game_type_cd, descr)
57 values('dom', 'Domination');
58 insert into cd_game_type(game_type_cd, descr)
59 values('freezetag', 'Freezetag');
60 insert into cd_game_type(game_type_cd, descr)
61 values('ka', 'Keepaway');
62 insert into cd_game_type(game_type_cd, descr)
63 values('kh', 'Keyhunt');
64 insert into cd_game_type(game_type_cd, descr)
65 values('lms', 'Last Man Standing');
66 insert into cd_game_type(game_type_cd, descr)
67 values('nexball', 'Nexball');
68 insert into cd_game_type(game_type_cd, descr)
69 values('ons', 'Onslaught');
70 insert into cd_game_type(game_type_cd, descr)
71 values('rc', 'Race');
72 insert into cd_game_type(game_type_cd, descr)
73 values('cts', 'Complete This Stage');
74 insert into cd_game_type(game_type_cd, descr)
75 values('rune', 'Runematch');
76 insert into cd_game_type(game_type_cd, descr)
77 values('tdm', 'Team Deathmatch');
78 insert into cd_game_type(game_type_cd, descr)
79 values('duel', 'Duel');
80
81 -- weapons
82 insert into cd_weapon(weapon_cd, descr) values('laser', 'Laser');
83 insert into cd_weapon(weapon_cd, descr) values('shotgun', 'Shotgun');
84 insert into cd_weapon(weapon_cd, descr) values('uzi', 'Machine Gun');
85 insert into cd_weapon(weapon_cd, descr) values('grenadelauncher', 'Mortar');
86 insert into cd_weapon(weapon_cd, descr) values('electro', 'Electro');
87 insert into cd_weapon(weapon_cd, descr) values('crylink', 'Crylink');
88 insert into cd_weapon(weapon_cd, descr) values('nex', 'Nex');
89 insert into cd_weapon(weapon_cd, descr) values('hagar', 'Hagar');
90 insert into cd_weapon(weapon_cd, descr) values('rocketlauncher', 'Rocket Launcher');
91 insert into cd_weapon(weapon_cd, descr) values('minstanex', 'MinstaNex');
92 insert into cd_weapon(weapon_cd, descr) values('rifle', 'Camping Rifle');
93 insert into cd_weapon(weapon_cd, descr) values('fireball', 'Fireball');
94 insert into cd_weapon(weapon_cd, descr) values('minelayer', 'Minelayer');
95 insert into cd_weapon(weapon_cd, descr) values('seeker', 'T.A.G. Seeker');
96 insert into cd_weapon(weapon_cd, descr) values('tuba', '@!#%''n Tuba');
97 insert into cd_weapon(weapon_cd, descr) values('hlac', 'Heavy Laser Assault Cannon');
98 insert into cd_weapon(weapon_cd, descr) values('hook', 'Grappling Hook');
99 insert into cd_weapon(weapon_cd, descr) values('porto', 'Port-O-Launch');
100
101 -- achievements
102 insert into cd_achievement(achievement_cd, descr, active_ind)
103 values(1, 'Play a game online.', 'Y');
104 insert into cd_achievement(achievement_cd, descr, active_ind)
105 values(2, 'Play each of the game types.', 'Y');
106 insert into cd_achievement(achievement_cd, descr, active_ind)
107 values(3, 'Register online.', 'Y');
108 insert into cd_achievement(achievement_cd, descr, active_ind)
109 values(4, 'Get higher than 50% nex accuracy in a single game.', 'Y');
110 insert into cd_achievement(achievement_cd, descr, active_ind)
111 values(5, 'Play in 50 games.', 'Y');
112 insert into cd_achievement(achievement_cd, descr, active_ind)
113 values(6, 'Play in 100 games.', 'Y');
114 insert into cd_achievement(achievement_cd, descr, active_ind)
115 values(7, 'Play in 250 games.', 'Y');
116 insert into cd_achievement(achievement_cd, descr, active_ind)
117 values(8, 'Play in 500 games.', 'Y');
118 insert into cd_achievement(achievement_cd, descr, active_ind)
119 values(9, 'Play in 1000 games.', 'Y');
120 insert into cd_achievement(achievement_cd, descr, active_ind)
121 values(10,'Get more than 10 carrier kills in a single game.', 'Y');
122 insert into cd_achievement(achievement_cd, descr, active_ind)
123 values(11,'Get more than 5 captures in a single game.', 'Y');
124 insert into cd_achievement(achievement_cd, descr, active_ind)
125 values(12,'Accumulate 10 hours of play.', 'Y');
126 insert into cd_achievement(achievement_cd, descr, active_ind)
127 values(13,'Accumulate 24 hours of play.', 'Y');
128 insert into cd_achievement(achievement_cd, descr, active_ind)
129 values(14,'Accumulate 48 hours of play.', 'Y');
130 insert into cd_achievement(achievement_cd, descr, active_ind)
131 values(15,'Accumulate 1 week of play.', 'Y');
132 insert into cd_achievement(achievement_cd, descr, active_ind)
133 values(16,'Get more than 5 laser kills in a single game.', 'Y');
134 insert into cd_achievement(achievement_cd, descr, active_ind)
135 values(17,'Get more than 10 laser kills in a single game.', 'Y');
136 insert into cd_achievement(achievement_cd, descr, active_ind)
137 values(18,'Get greater than 25% accuracy with the machine gun in a single game.', 'Y');
138 insert into cd_achievement(achievement_cd, descr, active_ind)
139 values(19,'Get more frags than deaths in a single game.', 'Y');
140 insert into cd_achievement(achievement_cd, descr, active_ind)
141 values(20,'Be the highest scorer in a game.', 'Y');
142
143 -- mutators
144 --insert into cd_mutator(mutator_cd, name)
145 --values(1, 'g_dodging');
146 --insert into cd_mutator(mutator_cd, name)
147 --values(2, 'g_minstagib');
148 --insert into cd_mutator(mutator_cd, name)
149 --values(3, 'g_nix');
150 --insert into cd_mutator(mutator_cd, name)
151 --values(4, 'g_rocket_flying');
152 --insert into cd_mutator(mutator_cd, name)
153 --values(5, 'g_weaponarena');
154 --insert into cd_mutator(mutator_cd, name)
155 --values(6, 'g_start_weapon_laser');
156 --insert into cd_mutator(mutator_cd, name)
157 --values(7, 'sv_gravity');
158 --insert into cd_mutator(mutator_cd, name)
159 --values(8, 'g_cloaked');
160 --insert into cd_mutator(mutator_cd, name)
161 --values(9, 'g_grappling_hook');
162 --insert into cd_mutator(mutator_cd, name)
163 --values(10, 'g_midair');
164 --insert into cd_mutator(mutator_cd, name)
165 --values(11, 'g_vampire');
166 --insert into cd_mutator(mutator_cd, name)
167 --values(12, 'g_pinata');
168 --insert into cd_mutator(mutator_cd, name)
169 --values(13, 'g_weapon_stay');
170 --insert into cd_mutator(mutator_cd, name)
171 --values(14, 'g_bloodloss');
172 --insert into cd_mutator(mutator_cd, name)
173 --values(15, 'g_jetpack');
174
175 -- bots and untracked players have special records in player
176 insert into players (nick) values ('Bot');
177 insert into players (nick) values ('Untracked Player');
178
179 -- triggers 
180 \i triggers/games_ins_trg.sql
181 \i triggers/player_game_stats_ins_trg.sql
182 \i triggers/player_weapon_stats_ins_trg.sql
183
184 -- version tracking
185 insert into db_version(version, descr) values('1.0.0', 'Initial build');
186
187 commit;