Datenbanken/Lösung/Aufgabe 5.sql
H4CK3R-01 f35349795f Initial commit of task #5
Not yet fully functional
2022-05-18 19:20:02 +02:00

62 lines
3.0 KiB
SQL

USE project;
/*
---------------------------------- 1 ----------------------------------
Zu jeder Person soll aufgezeichnet werden, wann dies Person wieviel von
welchem Produkt zu sich nimmt. Daraus soll eine Sicht erstellt werden, die anzeigt, wie viel
Prozent der Tagesmenge erreicht wurde und wieviel von welchen Nährstoffen konsumiert
wurde. Idealerweise gibt es ein Rechtekonzept dafür (ggfs. als SQL-Kommentar im Skript).
Wird dabei gegen Vorgaben (Kalorienvorgaben, vegetarisch, Allergene, etc.) verstoßen, so
soll das in der Sicht angezeigt werden. Wenn der Tag „ok“ ist, soll das markiert werden,
ansonsten soll angezeigt werden, gegen was verstoßen wurde.
-----------------------------------------------------------------------
Rechtekonzept:
Als normaler Benutzer sollte man nur Zugriff auf seine eigenen Daten haben.
Als privilegierter Nutzer (z.B. Admin) kann man alle Daten sehen
*/
DROP VIEW IF EXISTS Menu_Naehrwerte;
CREATE VIEW Menu_Naehrwerte AS
(
SELECT Menuname,
GROUP_CONCAT(DISTINCT Produktname SEPARATOR ', ') AS 'Produkte',
ROUND(SUM(Fett * (SELECT Menge FROM Menge WHERE MengenID = M.MengenID) / 100), 2) AS 'Fett',
ROUND(SUM(Kohlenhydrate * (SELECT Menge FROM Menge WHERE MengenID = M.MengenID) / 100), 2) AS 'Kohlenhydrate',
ROUND(SUM(Eiweiss * (SELECT Menge FROM Menge WHERE MengenID = M.MengenID) / 100), 2) AS 'Eiweiss',
ROUND(SUM(Brennwert * (SELECT Menge FROM Menge WHERE MengenID = M.MengenID) / 100), 2) AS 'Brennwert',
GROUP_CONCAT(DISTINCT Allergenbezeichnung SEPARATOR ', ') AS 'Allergene',
GROUP_CONCAT(DISTINCT E_Nummer SEPARATOR ', ') AS 'Zusatzstoff'
FROM Menu
JOIN Menucontent M on Menu.MenuID = M.MenuID
JOIN Menge M3 on M.MengenID = M3.MengenID
JOIN Produkt P on M3.ProduktID = P.ProduktID
JOIN Naehrwerte N on P.ProduktID = N.ProduktID
JOIN enthaeltAllergen eA on P.ProduktID = eA.ProduktID
JOIN Allergen A on A.AllergenID = eA.AllergenID
LEFT JOIN enthaeltZusatzstoff eZ on P.ProduktID = eZ.ProduktID
GROUP BY Menuname);
# TODO Compare Menu_Naehrwerte.Allergene and Menu_Naehrwerte.Zusatzstoff with Allergie and Zusatzstoffunverträglichkeit
DROP VIEW IF EXISTS Aufgabe_5;
CREATE VIEW Aufgabe_5 AS
(
SELECT Personenvorname,
Personenname,
Naehrwertziel,
MN.Brennwert,
CONCAT(MN.Brennwert / Naehrwertziel * 100, '%') AS Naehrwertziel_Prozent,
MN.Fett,
MN.Kohlenhydrate,
MN.Eiweiss,
IF(MN.Brennwert / Naehrwertziel * 100 <= 100, 'OK', 'Naehrwertziel überschritten') AS Naehrwert_OK,
M.Menuname,
Allergene,
Zusatzstoff
FROM konsumiert
JOIN Menu M on M.MenuID = konsumiert.MenuID
JOIN Person P on P.PersonID = konsumiert.PersonID
JOIN Menu_Naehrwerte MN on M.Menuname = MN.Menuname);