Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Zapytanie - pogrupowane według godziny.
srob
post
Post #1





Grupa: Zarejestrowani
Postów: 24
Pomógł: 0
Dołączył: 19.07.2006

Ostrzeżenie: (0%)
-----


Witam.

Mam problem z sformułowaniem zapytania. Chodzi mi oto aby zapytanie pogrupowało wynik według godziny bez minut np (8,9,10...) i wypisało ile jest wpisów z danej godziny, format czasu w bazie mam w takiej postaci hh:mm:ss. Szukałem w google ale nic nie znalazłem co by mi podpowiedziało.

Pozdrawiam

Ten post edytował srob 9.10.2010, 20:18:09
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 7)
Zigi
post
Post #2





Grupa: Zarejestrowani
Postów: 57
Pomógł: 3
Dołączył: 20.11.2004

Ostrzeżenie: (0%)
-----


Wyskrobałem takie zapytanie:
  1. SELECT SUBSTRING(`created`, 12, 2) AS test, count(id) FROM `zdarzenia` GROUP BY test

Musisz tylko w SUBSTRING zmienić drugi parametr na 0, bo ja mam daty zapisane jako dzień i godzina i powinno już być dobrze.
Go to the top of the page
+Quote Post
srob
post
Post #3





Grupa: Zarejestrowani
Postów: 24
Pomógł: 0
Dołączył: 19.07.2006

Ostrzeżenie: (0%)
-----


Dzięki za podpowiedz ale nie działa prawidłowo.
Moje zapytanie:

  1. SELECT SUBSTRING(`godzina`, 12,0) AS DATA, count(godzina) FROM `log` GROUP BY godzina


wynik jest rozbity na godziny z minutami. A chciałem by pokazał wynik z pełnej godziny i nie brał pod uwagę minut tylko godziny.
Go to the top of the page
+Quote Post
kefirek
post
Post #4





Grupa: Zarejestrowani
Postów: 781
Pomógł: 256
Dołączył: 29.06.2008

Ostrzeżenie: (0%)
-----


  1. SELECT COUNT(godzina) AS godzina FROM (
  2. SELECT SUBSTRING(DATA, 1, 2) AS godzina
  3. FROM test ) AS tab GROUP BY godzina
Go to the top of the page
+Quote Post
Zigi
post
Post #5





Grupa: Zarejestrowani
Postów: 57
Pomógł: 3
Dołączył: 20.11.2004

Ostrzeżenie: (0%)
-----


Napisałem żebyś zmienił wartość drugiego parametru na 0 a nie trzeciego. Przez 0 w ostatnim parametrze zwracany jest pusty ciąg. Polecam zapoznanie się z funkcją SUBSTRING
  1. http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_substring
. Dlaczego grupowanie robisz po kolumnie godzina, a nie po DATA przez analogie z zapytaniem podanym przeze mnie?

Teraz przeczytałem, że SUBSTRING liczy od 1 pozycje więc należy wstawić 1 a nie 0 żeby zwracał od pierwszego znaku.

Ten post edytował Zigi 9.10.2010, 18:33:29
Go to the top of the page
+Quote Post
srob
post
Post #6





Grupa: Zarejestrowani
Postów: 24
Pomógł: 0
Dołączył: 19.07.2006

Ostrzeżenie: (0%)
-----


Może zle napisałem co chce osiągnąć.
Mam tabele gdzie są zapisane logi (czyli "adres, data, godzina"). I chce zapytaniem wyciągnąć coś takiego:

data | godzina | ilość
09-10 | 8 | 24
09-10 | 9 | 10
------ || -------

żeby zapytanie grupowało wszystkie odwiedziny do danego dnia i godziny.
Myślę że teraz dobrze opisałem:)

Ten post edytował srob 9.10.2010, 20:20:26
Go to the top of the page
+Quote Post
erix
post
Post #7





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




  1. GROUP BY DATA, godzina

?


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
srob
post
Post #8





Grupa: Zarejestrowani
Postów: 24
Pomógł: 0
Dołączył: 19.07.2006

Ostrzeżenie: (0%)
-----


nie działa, błąd skryptu.

udało mi się sklecić takie zapytanie które daje pożądany efekt, coś takiego:

  1. SELECT COUNT(godzina) AS ilosc, DATA, godzina FROM (
  2. SELECT DATA, SUBSTRING(godzina, 1, 2) AS godzina
  3. FROM log WHERE DATA ='2010-10-10') AS godzina GROUP BY godzina


tylko chciał bym by zapytanie generowało wynik dla wszystkich dni a nie tylko dla daty którą podam w zapytaniu.

Udało mi się. Zapytanie wygląda tak:

  1. SELECT COUNT(godzina) AS ilosc, DATA, godzina FROM (
  2. SELECT DATA, SUBSTRING(godzina, 1, 2) AS godzina
  3. FROM log ) AS godzina WHERE DATA >'2000-01-01' GROUP BY DATA,godzina


Dzięki wszystkim za pomoc.

Ten post edytował srob 10.10.2010, 16:47:39
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 19.08.2025 - 10:17