adam882
22.09.2014, 06:58:41
Witam!
Posiadam tabelę "miasta"
ID | NAZWA | DATA
kolumna "data" posiada dane w formacie unixowym.
W jaki sposób skonstruować zapytanie sql lub jakich użyć funkcji, aby można było wyświetlić rekordy z konkretnego miesiąca i roku ? Próbowałem użyć FROM_UNIXTIME, ale coś mi nie wyszło. Proszę o pomoc.
irekk
22.09.2014, 07:06:25
Można tak:
WHERE from_unixtime(DATA, '%Y-%m') = ?
i przekazujesz datę w formacie 'YYYY-MM'
Ale lepiej jest użyć:
WHERE DATA BETWEEN ? AND ?
Gdzie przekazujesz interesujący zakres wyrażony w timestampach.
adam882
22.09.2014, 07:11:13
Dzięki.
Chciałbym się jeszcze zapytać, czy zapisywanie daty w formacie unixowym jest dobrym rozwiązaniem?
(pomijając, że nie da się tym formatem zapisać bardzo starych dat - chyba sprzed 1970r.)
Pyton_000
22.09.2014, 07:18:39
Temat rzeka m.in.
- Date potrzebuje 3 bajty, Datetime 8 a timestamp 4
- timestamp jest zapisywany w UTC i konwertowany do strefy czasowej w której został zapisany.
- timestamp ma ograniczenie od 1970 do 2038
itd..
poczytaj o różnicach a znajdziesz ich jeszcze kilka
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.