Reisplanning voor vluchtgegevens

Hiërarchische en recursieve queries in SQL Server

Jasmin Ludolf

Content Developer

Scoreboard van een luchthaven

Voorbeeld van een luchthaven-scoreboard

Hiërarchische en recursieve queries in SQL Server

Hoe is een vluchtendataset opgebouwd?

Vertrek Aankomst Vluchtnummer Kosten Tijd
Londen Parijs LH3827 90 2
Wenen New York MH2370 379 8
New York Parijs LH9832 489 9
Wenen Parijs SU2389 200 3
Londen Chicago OP1230 650 10
New York Chicago NL5460 150 2
Hiërarchische en recursieve queries in SQL Server

Hoe bouw je een vluchtroute?

Een afbeelding met alle mogelijke vluchtroutes wereldwijd

  • Gebruik recursie om alle mogelijke vluchtroutes te krijgen
  • Een route wordt bepaald door de vertrek- en bestemmingsluchthaven
  • Beperk het aantal overstappen voor realistische routes
Hiërarchische en recursieve queries in SQL Server

Een vluchtroute opbouwen - stap 1

WITH flightRoute (Departure, Arrival, stops) AS(
  -- Anchor query
  SELECT f.Departure,f.Arrival, 0
      FROM flightPlan f
      WHERE Departure = 'Vienna'
  -- Recursive query
  UNION ALL
      SELECT p.Departure, f.Arrival, p.stops + 1
      FROM flightPlan f, flightRoute p
      WHERE p.Arrival = f.Departure AND 
        p.stops < 5 
)
SELECT Departure, Arrival, stops
    FROM flightRoute
+-----------+---------------+--------+
| Departure | Arrival       | stops  |
|-----------|---------------|--------|
| Vienna    | Paris         | 2      |
| Vienna    | San Francisco | 3      |
| Vienna    | Vienna        | 3      |
| Vienna    | Frankfurt     | 3      |
| ...       | ...           | ...    |
+-----------+---------------+--------+
Hiërarchische en recursieve queries in SQL Server

Een vluchtroute opbouwen - stap 2

WITH flightRoute (Departure, Arrival, stops, route) AS(
  SELECT f.Departure, f.Arrival, 0, 
  CAST(Departure + '->' + Arrival AS VARCHAR(MAX))
      FROM flightPlan f
      WHERE Departure = 'Vienna'

UNION ALL SELECT p.Departure, f.Arrival, p.stops + 1, p.totalCost + f.Cost, CAST(p.route + '->' + f.Arrival AS VARCHAR(MAX)) FROM flightPlan f, flightRoute p
WHERE p.Arrival = f.Departure AND p.stops < 5 )
  • Voeg route toe in het ankerlid

  • Volg routes in het recursieve lid

  • Beperk het aantal tussenstops

Hiërarchische en recursieve queries in SQL Server

Een vluchtroute opbouwen - resultaat

SELECT Departure, Arrival, Route
    FROM flightRoute
+-----------+--------------+-------------------------------------------+
| Departure | Arrival      | route                                     |
|-----------|--------------|-------------------------------------------+
| London    | New York     | London -> Vienna -> Chicago -> New York   |
| Vienna    | Chicago      | Vienna -> London -> Chicago               |        
| Paris     | Los Angeles  | Paris -> Toronto -> Los Angeles           |
| Chicago   | New York     | Chicago -> New York                       |
| Rome      | New York     | Rome -> London -> Chicago -> New York     |    
| ...       | ...          | ...                                       |
+-----------+--------------+-------------------------------------------+
Hiërarchische en recursieve queries in SQL Server

Zoeken naar mogelijke vluchten met grenzen

WITH flightRoute (Departure, Arrival, stops, totalCost, route) AS(
  SELECT f.Departure, f.Arrival, 0, Cost,
    CAST(Departure + '->' + Arrival AS NVARCHAR(MAX))
      FROM flightPlan f
      WHERE Departure = 'New York'
  UNION ALL
  SELECT  p.Departure, f.Arrival, p.stops+1, 
  p.totalCost + f.Cost, p.route + '->' + f.Arrival
      FROM flightPlan f, flightRoute p
      WHERE p.Arrival = f.Departure AND p.stops < '...' 
)
SELECT '...'    
    FROM flightRoute
    WHERE '...' ;

Vind alle mogelijke bestemmingsluchthavens waar:

  • De vertrekluchthaven vaststaat
    • New York
  • Het aantal stops is beperkt tot n
  • De output is beperkt door een voorwaarde
    • kostenlimiet
    • goedkoopste route naar een bestemming
Hiërarchische en recursieve queries in SQL Server

Laten we mogelijke vluchtroutes vinden!

Hiërarchische en recursieve queries in SQL Server

Preparing Video For Download...