123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- SELECT sm.datum, sm.kunde, sm.aufgabe, sm.anzahl,
- IFNULL(s7.anzahl, 'X') AS anzahl_7,
- IFNULL(s6.anzahl, 'X') AS anzahl_6,
- IFNULL(s5.anzahl, 'X') AS anzahl_5,
- IFNULL(s4.anzahl, 'X') AS anzahl_4,
- IFNULL(s3.anzahl, 'X') AS anzahl_3,
- IFNULL(s2.anzahl, 'X') AS anzahl_2,
- IFNULL(s1.anzahl, 'X') AS anzahl_1
- FROM `status_meldung` sm
- LEFT JOIN status_meldung AS s7 ON s7.datum = date_add(sm.datum, INTERVAL -7 DAY) AND s7.kunde = sm.kunde AND s7.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s6 ON s6.datum = date_add(sm.datum, INTERVAL -6 DAY) AND s6.kunde = sm.kunde AND s6.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s5 ON s5.datum = date_add(sm.datum, INTERVAL -5 DAY) AND s5.kunde = sm.kunde AND s5.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s4 ON s4.datum = date_add(sm.datum, INTERVAL -4 DAY) AND s4.kunde = sm.kunde AND s4.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s3 ON s3.datum = date_add(sm.datum, INTERVAL -3 DAY) AND s3.kunde = sm.kunde AND s3.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s2 ON s2.datum = date_add(sm.datum, INTERVAL -2 DAY) AND s2.kunde = sm.kunde AND s2.aufgabe = sm.aufgabe
- LEFT JOIN status_meldung AS s1 ON s1.datum = date_add(sm.datum, INTERVAL -1 DAY) AND s1.kunde = sm.kunde AND s1.aufgabe = sm.aufgabe
- WHERE sm.datum = '2017-06-06'
- SELECT DISTINCT a.datum, a.wochentag, a.feiertag, k.kunde, ka.aufgabe, k.system, k.bundesland, ka.start_soll,
- case
- when a.wochentag = 'Mo' and ka.ende_mo IS NOT NULL then ka.ende_mo
- when a.wochentag = 'Di' and ka.ende_di IS NOT NULL then ka.ende_di
- when a.wochentag = 'Mi' and ka.ende_mi IS NOT NULL then ka.ende_mi
- when a.wochentag = 'Do' and ka.ende_do IS NOT NULL then ka.ende_do
- when a.wochentag = 'Fr' and ka.ende_fr IS NOT NULL then ka.ende_fr
- when a.wochentag = 'Sa' and ka.ende_sa IS NOT NULL then ka.ende_sa
- when a.wochentag = 'So' and ka.ende_so IS NOT NULL then ka.ende_so
- else ka.ende_soll
- end as 'ende_soll',
- ka.woche,
- case
- when ka.woche = 'Mo-Fr' then a.mofr
- when ka.woche = 'Mo-Sa' then a.mosa
- when ka.woche = 'Mo-So' then a.moso
- when ka.woche = 'Di-So' then a.diso
- else 1
- end
- * ka.aktiv * if(a.datum >= ka.erster_status, 1, 0) as 'anstehend'
-
- FROM kunden k
- INNER JOIN arbeitstage a USING (bundesland)
- INNER JOIN kunden_aufgabe ka USING (kunde)
- WHERE a.datum <= date_add(now(), INTERVAL 1 DAY)
- AND a.datum >= date_add(now(), INTERVAL -20 DAY)
-
-
-
-
- LEFT JOIN status_meldung sm USING (datum, kunde)
- LEFT JOIN status_kommentar sk ON sm.kommentar_id = sk.id
- LEFT JOIN status_kommentar as sk2 ON a.datum = sk2.datum AND k.kunde = sk2.kunde
- WHERE {$datum} AND {$datum_bis} AND {$kunde} AND a.datum <= now() AND k.erster_status <= a.datum
- AND k.aktiv = 1
- ORDER BY a.datum, k.ende_soll
-
-
- end * if(sk.status <= 1, 0, 1) * if(sm.anzahl > 0 or (sm.anzahl is null and now() > date_add(concat(a.datum, ' ', k.ende_soll), INTERVAL 1 HOUR)), 1, 0) as fehler,
- if(sm.anzahl is null and now() > date_add(concat(a.datum, ' ', k.ende_soll), INTERVAL 1 HOUR), 1, 0) as fehlend,
-
|