Einzelnen Beitrag anzeigen

mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#1

(SQL) Kochrezept: Zutatenliste nach erster Verwendung (jede Zutat nur einmal)

  Alt 25. Aug 2022, 07:50
Datenbank: MS SQL • Version: 2019 • Zugriff über: JDBC
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)
Michael Justin

Geändert von mjustin (25. Aug 2022 um 07:56 Uhr) Grund: optionale Zusatzbedingung ergänzt
  Mit Zitat antworten Zitat