Gerichtete Graphen mit SQL lösen – Teil 1


Eines der bekanntesten und schwierigeren Probleme der Informatik findet sich im Bereich der ‚gerichteten Graphen‘. Ein gerichteter Graph ist eine finite Menge von Knoten, die durch eine Menge von Vektoren (Kanten) verbunden sind. Einen Knoten kann man sich als eine ‚Stadt‘ vorstellen, und jede Kante wäre dann eine ‚Flugverbindung‘ zwischen zwei Städten.

Es gibt eine Vielzahl von Algorithmen und Texten zu diesem Problem, zu Fragen wie: wie viele mögliche Routen gibt es, welche ist die kürzeste, und welche die schnellste Verbindung? Die meisten dieser Algorithmen sind prozedural oder greifen auf Rekursion zurück. Einfacher und hinsichtlich des Programmieraufwandes deutlich ökonomischer wird die Lösung komplexer Probleme mit gerichteten Graphen allerdings mit der deklarativen Sprache SQL.

Im folgenden Beispiel geht es um Flugverbindungen zwischen einzelnen Städten. Hierzu wird eine Tabelle erstellt, die einige imaginäre Daten aufnimmt:

Man kann nicht die CONNECT BY-Syntax verwenden, um herauszufinden, wie man von London nach Sao Paulo gelangt, denn es gibt Daten, die eine Schleife im Graphen erzeugen (Rückflug nach Sao Paulo):

Zur Lösung von Problemen mit gerichteten Graphen muss also eine temporäre Tabelle erstellt werden, die alle möglichen Pfade zwischen zwei Knoten aufnimmt. Dabei muss beachtet werden, dass bereits bearbeitete Pfade nicht dupliziert werden. Außerdem sollen bei diesem Beispiel Pfade unberücksichtigt bleiben, die zum Ausgangsort zurückführen. Zusätzlich kann die Zahl der Zwischenstationen bis zum Ziel aufgezeichnet sowie eine Beschreibung der gewählten Route ausgegeben werden.

Die temporäre Tabelle wird mit Hilfe des folgenden Codes erzeugt:

Page: 1 2

ZDNet.de Redaktion

Recent Posts

Studie: Ein Drittel aller E-Mails an Unternehmen sind unerwünscht

Der Cybersecurity Report von Hornetsecurity stuft 2,3 Prozent der Inhalte gar als bösartig ein. Die…

2 Tagen ago

HubPhish: Phishing-Kampagne zielt auf europäische Unternehmen

Die Hintermänner haben es auf Zugangsdaten zu Microsoft Azure abgesehen. Die Kampagne ist bis mindestens…

3 Tagen ago

1. Januar 2025: Umstieg auf E-Rechnung im B2B-Geschäftsverkehr

Cloud-Plattform für elektronische Beschaffungsprozesse mit automatisierter Abwicklung elektronischer Rechnungen.

3 Tagen ago

Google schließt schwerwiegende Sicherheitslücken in Chrome 131

Mindestens eine Schwachstelle erlaubt eine Remotecodeausführung. Dem Entdecker zahlt Google eine besonders hohe Belohnung von…

3 Tagen ago

Erreichbarkeit im Weihnachtsurlaub weiterhin hoch

Nur rund die Hälfte schaltet während der Feiertage komplett vom Job ab. Die anderen sind…

4 Tagen ago

Hacker missbrauchen Google Calendar zum Angriff auf Postfächer

Security-Experten von Check Point sind einer neuen Angriffsart auf die Spur gekommen, die E-Mail-Schutzmaßnahmen umgehen…

5 Tagen ago