SQL-Puzzle, am Beispiel "Schokoladenkuchen".
Aufgabenstellung:
alle Zutaten des Rezepts sollen in der Reihenfolge erscheinen, in der sie verarbeitet werden.
Jedoch sollen Zutaten, die zweimal verwendet werden, nur einmal im Ergebnis erscheinen.
Das gewünschte Ergebnis könnte z.B. so aussehen:
* Mehl
* Schokoflocken
* Zucker
* Butter
Schokoflocken werden im Rezept allerdings zweimal angegeben:
* erste Verwendung: im Teig
* zweite Verwendung: als Deko auf dem gebackenen Kuchen
Die zweite Verwendung soll ausgefiltert werden. Falsch wäre also diese Ausgabe:
* Mehl
* Schokoflocken
* Zucker
* Butter
* Schokoflocken
In
SQL scheint das Ausfiltern etwas knifflig zu sein.
Ich vermute es gibt im Bereich Materialwirtschaft / Stücklisten dafür ein Paradebeispiel.
Sollte ich eine Lösung finden, poste ich sie natürlich hier.
Tabellenaufbau wäre in etwa:
Rezept: ID, Name
Zutat: ID, Name
Zutaten des Rezepts: RezeptID, ZutatID, Reihenfolge-Nr
Das
SQL würde dann die Liste der RezeptID / ZutatID Paare aller Rezepte in der gewünschten Reihenfolge liefern.
(in meinem konkreten Einsatzfall kommt noch eine Bedingung hinzu: im Rezept kann eine Hauptzutat angegeben werden, diese muss natürlich auch in der Zutatenliste erscheinen, und wenn diese angegeben ist, dann muss sie in der Ergebnisliste an erster Stelle stehen, egal an welcher Stelle sie in den Verarbeitungsschritten erscheint)