Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MySQL] problem z datą,tylko MM-DD
wbijok
post
Post #1





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

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


Witam,
Piszę skrypt, który wyświetla pewne informacje zależnie od dnia roku. Przy czym nie ma znaczenia czy jest rok 2010 czy 2012. Zawsze np. pomiędzy 1 lipca a 31 sierpnia powinnien wyświetlić promocję wakacyjną. No i pytanie dotyczy przechowywania rekordów z datą w formacie MM-DD (bez YYYY) w bazie mysql. Nie mogę tego rozgryźć. Gdyby było z YYYY to nie stanowiłoby to żadnego problemu. Jak przechowywać taką datę w bazie?

Dzięki za sugestie.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 3)
jimmy0699
post
Post #2





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 27.07.2005

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


poprotu nie validuj po roku tylko po dniach i miesiacach, przykladowo:
  1. if(date("m")>=7 && date("d")>=1) {
  2. //wyswietl promocje
  3. }


pierwsze co wpadlo do glowy
Go to the top of the page
+Quote Post
Wicepsik
post
Post #3





Grupa: Zarejestrowani
Postów: 1 575
Pomógł: 299
Dołączył: 26.03.2009

Ostrzeżenie: (20%)
X----


Możesz też to zrobić na podstawie dnia roku. Sprawdzasz czy rok jest przestępny i dodajesz od lutego +1.
  1. if(date('z') < 32) echo 'Jest styczen';
Go to the top of the page
+Quote Post
jimmy0699
post
Post #4





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 27.07.2005

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


nie bardzo rozumiem co masz na mysli po tym kodzie ktory wkleiles. rok przestepny zwroci funkcja :
  1. <?php
  2. $przestepczosc_roku = date("L");
  3.  
  4. /**
  5.  * zmienna bedzie rowna 1 jesli rok jest przestepny albo 0 jesli rok nie jest.
  6. **/
  7. ?>


swoja droga zastanowilem sie chwile nad tym twoim problemem i doszedlem do wniosku ze prawdopodobie masz te promocje zapisane dzies w bazie danych, w jakim dniu jaka promocja itp.. i chcialbys zeby skrypt pobieral z bazy danych dzien i miesiac i porownywal z aktualnym dniem i miesiacem i wyswietlal odpowiedia promocje.
łatwym ale nie najlepszym rozwiazaniem bedzie cos takiego:
  1. $dane = mysql_query("select * from promocje");
  2. while ($rekord = mysql_fetch_array($dane)) {
  3. $a = explode(" ", $rekord['data']);
  4. $b = explode("-", $a[0]);
  5. if(date("m")==$b[1] && date("d")==$b[2]) {
  6. //wyswietl promocje z bazy przykladowo
  7. echo "dzis jest ".$rekord['nazwa promocji'];
  8. }
  9. }


Ten post edytował jimmy0699 14.07.2010, 16:22:04
Go to the top of the page
+Quote Post

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

 



RSS Aktualny czas: 24.08.2025 - 12:00