polhub
2.03.2015, 17:45:29
Witam,
W bazie danych przechowuje informacje o zmianach statusu dokumentu. Mam 15 z góry zdefiniowanych statusów: 1, 2, 3, 4, ...14, 15
Po każdej zmianie statusu skrypt php zapisuje w bazie danych jedną linie - id_nr_dokumentu, nadany status oraz godzina nadania statusu
Kolumny w tabeli mam następujące: id, id_nrdok, status, godzina
Chciałbym otrzymać KOLUMNY:
numer dokumentu (id_nrdok)
data i godzina przejścia na status 2 (status)
data i godzina przejścia na status 12 (status)
mmmmmmm
2.03.2015, 18:41:41
SELECT numer_dokumentu, MIN(CASE WHEN nadany_status=2 THEN godzina_nadania END) status_2, MIN(CASE WHEN nadany_status=12 THEN godzina_nadania END) status_12 FROM tabela WHERE nadany_status IN (12,2) GROUP BY numer_dokumentu
polhub
4.03.2015, 07:56:02
Super, dzięki wielki!
A jak wyciagniać średnią (w godz) z różnicy tych dat?
Przy poniższym zapytaniu zwarac mi błąd: #1111 - Invalid use of group function
SELECT numer_dokumentu,
MIN(CASE WHEN nadany_status=2 THEN godzina_nadania END) status_2,
MIN(CASE WHEN nadany_status=12 THEN godzina_nadania END) status_12
AVG(TIMESTAMPDIFF(hour, MAX( CASE WHEN STATUS= 2 THEN czas END ),MAX( CASE WHEN STATUS= 12 THEN czas END ))) AS roznica
FROM tabela WHERE nadany_status IN (12,2)
GROUP BY numer_dokumentu