summaryrefslogtreecommitdiff
path: root/views/podiums.sql
blob: ec0bf63c2651a7e6b31ecaf0ddd6e51a9f6f2acc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
-- podium for each race, in order of finishing position
DROP VIEW IF EXISTS podium_sequences;
CREATE VIEW podium_sequences AS
   SELECT races.*,
      GROUP_CONCAT(CONCAT(drivers.forename, " ", drivers.surname)
         ORDER BY results.position ASC, results.driverId ASC)
      AS podium
   FROM results
   JOIN races ON results.raceId = races.raceId
   JOIN drivers ON results.driverId = drivers.driverId
   WHERE results.position IN (1,2,3)
   GROUP BY results.raceId;

-- podium for each race, in alphabetical order
DROP VIEW IF EXISTS podium_sets;
CREATE VIEW podium_sets AS
   SELECT races.*,
      GROUP_CONCAT(CONCAT(drivers.forename, " ", drivers.surname)
         ORDER BY drivers.surname ASC, drivers.forename ASC,
            drivers.driverRef ASC)
      AS podium
   FROM results
   JOIN races ON results.raceId = races.raceId
   JOIN drivers ON results.driverId = drivers.driverId
   WHERE results.position IN (1,2,3)
   GROUP BY results.raceId;

-- races in which the entire podium consisted of driver of nationality
-- yet to produce a drivers' world champion
DROP VIEW IF EXISTS non_champion_nationality_podiums;
CREATE VIEW non_champion_nationality_podiums AS
   SELECT raceId, year, name, podium FROM podium_sequences
   WHERE raceId NOT IN (
      SELECT results.raceId FROM results
         JOIN drivers ON drivers.driverId = results.driverId
         JOIN races ON races.raceId = results.raceId
         WHERE drivers.nationality IN (
            SELECT nationality FROM world_drivers_champions
            WHERE year < races.year
         ) AND position IN (1,2,3)
   );