Einzelnen Beitrag anzeigen

mjustin

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

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

  Alt 26. Aug 2022, 11:16
Hier ist das Fiddle mit der Zusatzanforderung: http://sqlfiddle.com/#!18/bb18e/11/0

* es gibt in jedem Rezept eine optionale Zutat (z.B. hier 'Ahornsirup')
* die optionale Zutat muss im Ergebnis ebenfalls ausgegeben werden
* falls die optionale Zutat auch in der Liste der Zutaten enthalten ist, darf sie dennoch nur einmal erscheinen
* sie soll im Ergebnis an erster Stelle stehen

(Idee: das Gericht wird zusammen mit dieser optionalen Zutat serviert, damit man nach Belieben 'Nachwürzen' kann).

In den Beispieldaten ist im Nusskuchen die Zutat 'Ahornsirup' daher als optionale Zutat im Rezept sowie in der Zutatenliste enthalten.

Code:
create table rezept (
  rezeptid int,
  optionalezutatid int,
  bezeichnung nvarchar(80)
);
 
create table zutat (
  zutatid int,
  bezeichnung nvarchar(80)
);
 
create table zutaten (
rezeptid int,
zutatid int,
lfdnr int
);

insert into rezept values(111, null, 'Schokokuchen');
insert into rezept values(222, 6, 'Nusskuchen');

insert into zutat values (1,'Mehl');
insert into zutat values (2,'Schokoflocken');
insert into zutat values (3,'Butter');
insert into zutat values (4,'Zucker');
insert into zutat values (5,'Nüsse');
insert into zutat values (6,'Ahornsirup');

insert into zutaten values (111,1,1);
insert into zutaten values (111,2,2);
insert into zutaten values (111,3,3);
insert into zutaten values (111,4,4);
insert into zutaten values (111,2,5);

insert into zutaten values (222,1,1);
insert into zutaten values (222,5,2);
insert into zutaten values (222,3,3);
insert into zutaten values (222,4,4);
insert into zutaten values (222,5,5);
insert into zutaten values (222,6,6);
Code:
with CTE as (
  select rezept.rezeptid, 'O' as optional, null as lfdnr, zutat.bezeichnung as bezeichnung
from rezept
join zutat on zutat.zutatid = rezept.optionalezutatid
union all
select rezept.rezeptid, 'P' as optional, zutaten.lfdnr, zutat.bezeichnung as bezeichnung
from zutaten
join zutat on zutat.zutatid = zutaten.zutatid
join rezept on rezept.rezeptid = zutaten.rezeptid
where lfdnr=(select min(lfdnr) from zutaten z where z.rezeptid=zutaten.rezeptid and z.zutatid=zutaten.zutatid)
and (rezept.optionalezutatid is null or zutaten.zutatid <> rezept.optionalezutatid)
  )
  select rezept.rezeptid, (select concat(bezeichnung, ' ') from cte where cte.rezeptid = rezept.rezeptid for xml path(''))
  from rezept
Ergebnis:

Code:
Rezept-ID  Zutaten
111        Mehl Schokoflocken Butter Zucker
222        Ahornsirup Mehl Butter Zucker Nüsse
Michael Justin
  Mit Zitat antworten Zitat