Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Pobieranie rekordów z podanej daty
Forum PHP.pl > Forum > Bazy danych > MySQL
wachcio
Witam

Co robię źle w tym zapytaniu?

  1. $data_odczytow = new DateTime('2017-03-29');
  2. $data_odczytow = date_format($data_odczytow, 'Y-m-d H:i:s');
  3. $data_o = '2017-03-29';
  4. $rezultat_temp_max_doba = mysqli_query($polaczenie, "SELECT `temperatura`, `data_odczytu` FROM `AVR` WHERE DATE (`data_odczytu`) = DATE($data_odczytow) ORDER BY `temperatura` DESC LIMIT 1");
  5. $rezultat_temp_max_doba2 = mysqli_query($polaczenie, "SELECT `temperatura`, `data_odczytu` FROM `AVR` WHERE DATE (`data_odczytu`) = DATE($data_o) ORDER BY `temperatura` DESC LIMIT 1");
  6. $rezultat_temp_min_doba = mysqli_query($polaczenie, "SELECT `temperatura`, `data_odczytu` FROM `AVR` WHERE DATE (`data_odczytu`) = DATE('2017-03-29' ) ORDER BY `temperatura` ASC LIMIT 1");


Rezultatem pierwszego i drugiego zapytania jest "0". Natomiast trzecie działa poprawnie. Czemu?
mmmmmmm
W pierwszych dwóch brakuje '
Powinno być:
  1. $rezultat_temp_max_doba = mysqli_query($polaczenie, "SELECT `temperatura`, `data_odczytu` FROM `AVR` WHERE DATE (`data_odczytu`) = DATE('$data_odczytow') ORDER BY `temperatura` DESC LIMIT 1");
wachcio
Cytat(mmmmmmm @ 31.03.2017, 07:15:44 ) *
W pierwszych dwóch brakuje '
Powinno być:
  1. $rezultat_temp_max_doba = mysqli_query($polaczenie, "SELECT `temperatura`, `data_odczytu` FROM `AVR` WHERE DATE (`data_odczytu`) = DATE('$data_odczytow') ORDER BY `temperatura` DESC LIMIT 1");


Myślałem, że skoro odwołuję się do zmiennej to nie muszę dawać apostrofów. Jednak nie pomyślałem o tym, że odnoszą się one do MySQL a nie PHP... Oczywiście działa jak należy smile.gif
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.