Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php][mysql] Format daty - jaki wybrać?
Forum PHP.pl > Forum > Przedszkole
mk321
Tworzę stronę (newsy, głosowanie itd) i nie jestem pewny jaki wybrać format daty.
Datę będę zapisywał w bazie MySQL, będę według niej sortował. Chcę dobrze wybrać by później nie mieć z tym problemów (czytałem, że przy przenoszeniu bazy są problemy z formatem daty).
Oczywiście dla użytkownika format daty musi być w miarę normalny do odczytania.

Wydaje się na początku naturalne:
  1. date("d.m.Y H:i:s")
Cytat
08.10.2010 16:52:04
Ale spacja w środku, do tego rok w środku... Da się to posortować w MySQL?

To może od największego do najmniejszego:
  1. date("Y.m.d H:i:s")
Cytat
2010.10.08 16:56:01
Było by lepiej sortować?

A może uniksowe sekundy:
Cytat
1286570936
Ale wtedy to mam problem z "normalnym" wyświetleniem.
nospor
Data w bazie danych ma byc datą.
W bazie danych pole z datą ma typ DATE_TIME - tego sie trzymaj i nie wydziwiaj smile.gif
Ulysess
nospar a co złego jest trzymaniu daty w formie UNIX questionmark.gif
nospor
@Ulysess bardziej mi chodzilo by nie cudował w stylu date("d.m.Y H:i:s") smile.gif
Tu są typy datowe:
http://dev.mysql.com/doc/refman/4.1/en/dat...time-types.html
Ich się należy trzymac
mk321
Cytat(nospor @ 8.10.2010, 23:01:20 ) *
W bazie danych pole z datą ma typ DATE_TIME
Chyba chodziło o DATETIME, czy coś przeoczyłem?

To zrobiłem tak (według dokumentacji):
W tabeli dodana kolumna:
  1. ...
  2. DATA DATETIME,
  3. ...
Jak dodaje rekord to muszę (czy może się da żeby baza sobie sama wpisywała? ^^ ) z php wprowadzić datę czyli:
  1. ...
  2. date("Y-m-d H:i:s")
  3. ...
I dostaje w bazie:
Cytat
2010-10-08 18:06:07
I jak się domyślam baza już będzie umiała sobie to posortować, i nie będę miał problemów z formatem (ani nie będzie wstyd pokazać ^^ )?


@Ulysess: to złego, że ja nie będę umiał tego normalnie wyświetlić tongue.gif

Dzięki za porady (nie wiedziałem o gotowym typie danych na datę).

minolone
Nie musisz wprowadzać daty w postaci
  1. date("Y-m-d H:i:s")

wystarczy że w zapytaniu do bazy dasz " now() " cos mniej wiecej takiego
  1. INSERT INTO `baza_danych`.`tabela_data` (`data`) VALUES (now())


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.