Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MYSQL] Zapytanie o przedział czasu, Zapytanie z wykorzystaniem BETWEEN
mefjiu
post 9.06.2008, 18:16:49
Post #1





Grupa: Zarejestrowani
Postów: 313
Pomógł: 5
Dołączył: 22.03.2005

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


Chcę pobrać z mysql dane które były dodane dziś tzn ich data jest z przedziału
2008.06.09 00:00:01 do 2008.06.09 23:59:59
Wymyśliłem że można to zrobić jako przedział z BETWEEN, ale jeżeli jest prostszy sposób to proszę o info.

A to zapytanie z moim sposobem ale nie działa, mam problem skonwertowaniem dat aby to działało poprawnie

Datę w bazie mam typu UNIX.
  1. SELECT * FROM `startowa_history_position` WHERE date BETWEEN UNIX_TIMESTAMP(GET_FORMAT(NOW(),'JIS')) AND UNIX_TIMESTAMP(DATE_ADD(NOW(),INTERVAL 1 DAY))


Proszę o wszelka pomoc
Go to the top of the page
+Quote Post
phpion
post 9.06.2008, 19:07:30
Post #2





Grupa: Moderatorzy
Postów: 6 072
Pomógł: 861
Dołączył: 10.12.2003
Skąd: Dąbrowa Górnicza




Moim zdaniem za bardzo kombinujesz. Wystarczy, że z timestampa wyciągniesz samą datę (czyli DATE(pole_z_data)) porównasz z datą dzisiejszą czyli z CURDATE(). I po sprawie.
Go to the top of the page
+Quote Post
mefjiu
post 9.06.2008, 19:11:33
Post #3





Grupa: Zarejestrowani
Postów: 313
Pomógł: 5
Dołączył: 22.03.2005

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


Ale to zrobić w zapytaniu mysql ? czy już po stronie php ?
lepiej by było zrobić to po stronie mysql i jeżeli tak to nie wiem jak to zrobić :-(
Go to the top of the page
+Quote Post
phpion
post 9.06.2008, 19:17:56
Post #4





Grupa: Moderatorzy
Postów: 6 072
Pomógł: 861
Dołączył: 10.12.2003
Skąd: Dąbrowa Górnicza




Jak to nie wiesz? Zwykły WHERE. W stylu WHERE DATE(pole_z_data)=CURDATE(). Nie wiem czy nie trzeba będzie przekonwertować czasu z timestampa no ale to już sobie sprawdź empirycznie.
Go to the top of the page
+Quote Post
mefjiu
post 9.06.2008, 19:49:08
Post #5





Grupa: Zarejestrowani
Postów: 313
Pomógł: 5
Dołączył: 22.03.2005

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


lol a ja myślałem że to jakoś skomplikowane :-) ok idę kombinować dzięki.

jednak jest skomplikowane :-)
  1. SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(date), '%Y-%m-%d') AS datka, date FROM `startowa_history_position`


Taki zapis nie działa a ja już nie mam pojęcia jak to zrobić inaczej

proszę o jakieś informacje
Go to the top of the page
+Quote Post
phpion
post 9.06.2008, 19:55:59
Post #6





Grupa: Moderatorzy
Postów: 6 072
Pomógł: 861
Dołączył: 10.12.2003
Skąd: Dąbrowa Górnicza




Cytat(mefjiu @ 9.06.2008, 19:16:49 ) *
Chcę pobrać z mysql dane które były dodane dziś

Więc:
  1. SELECT * FROM `startowa_history_position` WHERE DATE(FROM_UNIXTIME(`date`))=CURDATE();

Powinno śmigać.
Go to the top of the page
+Quote Post
mefjiu
post 9.06.2008, 20:00:49
Post #7





Grupa: Zarejestrowani
Postów: 313
Pomógł: 5
Dołączył: 22.03.2005

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


Jesteś najlepszy :-) dzięki pięknie działa.
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 Wersja Lo-Fi Aktualny czas: 18.06.2025 - 23:39