Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Operacje na datach
Forum PHP.pl > Forum > PHP
shpaque
Witajcie serdecznie,
długo mnie nie było bo jednak trochę opanowałem php'a smile.gif na tyle żeby nie zawracać Wam głowy, jednak stanąłem teraz na dość sprawie logicznej, mianowicie jak powinien być napisany warunek (bo konwersja daty na każdy sposób mnie już wykańcza). Najpierw opiszę przypadek:
- mamy jakiś event, który zaczyna się kiedyś i kończy - jak zabezpieczyć żeby dodając lub edytując inny - skrypt sprawdził czy się na siebie nie nałożą (datami/czasami rozpoczęcia lub zakończenia), czyli aby czas rozpoczecia nowego/edytowanego eventu nie wszedl miedzy czas roz->zak innego i czas zakonczenia nie zrobil tego samego

  1. $sessionTimeStart = new DateTime($_SESSION['test']['timeStart']);
  2. $sessionTimeStart -> format('H:i:s');
  3. $sessionTimeEnd = new DateTime($_SESSION['test']['timeEnd']);
  4. $sessionTimeEnd -> format('H:i:s');
  5.  
  6. foreach ($testsDataBase -> test as $t) {
  7. $foreachTimeStart = new DateTime((string)$t -> timeStart);
  8. $foreachTimeStart -> format('H:i:s');
  9. $foreachTimeEnd = new DateTime((string)$t -> timeEnd);
  10. $foreachTimeEnd -> format('H:i:s');
  11.  
  12. if (strtotime($sessionTimeStart) >= strtotime($foreachTimeStart) && strtotime($sessionTimeStart) < strtotime($foreachTimeEnd)) {
  13. echo "<script>alert('Czas rozpoczęcia testu koliduje z innym testem!');</script>";
  14. echo "<script>history.back();</script>";
  15. }
  16. else if ($sessionTimeEnd >= $foreachTimeStart && $sessionTimeEnd <= $foreachTimeEnd) {
  17. echo "<script>alert('Czas zakończenia testu koliduje z innym testem!');</script>";
  18. echo "<script>history.back();</script>";
  19. }
nospor
1) zajrzyj do manuala jaki parametr przyjmuje strtotime a co ty mu dajesz
2) No i najwazniejsze: masz obiekty DataTime i zamiast porownywac je to i tak nadal konwertujesz je do sekund... gdzie logika?

az korci by przeniesc na przedszkole tongue.gif

i w zasadzie 3)
Po co w ogole robisz to w php? Pobierasz z bazy wszystkie rekordy tylko po to by sprawdzic czy czas sie nie zgadza. przeciez to zarznie ci skrypt przy wiekszej ilosci rekordow. To sprawdzanie powinno sie odbyc juz w bazie
shpaque
konwertuje bo juz nie wiem o co chodzi - rozlozylem warunki na czynniki pierwsze i jedno mi sie nie zgadza - zostawilem specjalnie jeden event ktory powiedzmy zaczyna sie dzisiaj o 21:00 i konczy o 21:15, ale jak w nowym dam 21:16 jako rozpoczecie - wyskakuje komunikat ze czas koliduje... Problem w tym ze daty zapisane w formacie ('Y-m-d H:i:s') nie uwzgledniaja strefy czasowej wiec wg warunku jeszcze pozostaje nasze GMT+1, ktore dopiero puszcza jak dodam godzine... W ogole to jakos jest dziwnie - ale zobacze...

@EDIT
czyli zrobilem to tak (bez strtotime, sie udalo w koncu) - mam nadzieje ze to wszystkie logiczne warunki jakie moga wystapic w glowie uzytkownika:

  1. $sessionTimeStart = new DateTime($_SESSION['test']['timeStart']);
  2. $sessionTimeEnd = new DateTime($_SESSION['test']['timeEnd']);
  3.  
  4. foreach ($testsDataBase -> test as $t) {
  5. $foreachTimeStart = new DateTime((string)$t -> timeStart);
  6. $foreachTimeEnd = new DateTime((string)$t -> timeEnd);
  7.  
  8. if ($sessionTimeStart >= $foreachTimeStart && $sessionTimeStart <= $foreachTimeEnd) {
  9. echo "<script>alert('Czas rozpoczęcia testu koliduje z innym testem!');</script>";
  10. echo "<script>history.back();</script>";
  11. }
  12. else if ($sessionTimeStart <= $foreachTimeStart && ($sessionTimeEnd >= $foreachTimeStart && $sessionTimeEnd <= $foreachTimeEnd)) {
  13. echo "<script>alert('Czas zakończenia testu koliduje z innym testem!');</script>";
  14. echo "<script>history.back();</script>";
  15. }
  16. else if ($sessionTimeStart <= $foreachTimeStart && $sessionTimeEnd >= $foreachTimeEnd) {
  17. echo "<script>alert('W tym czasie odbywa się inny test!');</script>";
  18. echo "<script>history.back();</script>";
  19. }
  20. else if ($sessionTimeEnd >= $foreachTimeStart && $sessionTimeEnd <= $foreachTimeEnd) {
  21. echo "<script>alert('Czas zakończenia testu koliduje z innym testem!');</script>";
  22. echo "<script>history.back();</script>";
  23. }
  24. }
vokiel
Po co aż tyle warunków? Z tego co rozumiem, chcesz uniknąć kolizji, zatem:

Potraktuj to jak oś czasu
  1. /*
  2.   +------------------+
  3.   | istniejący event |
  4.   +------------------+
  5. ------------------------------------------------->
  6. +----+ +----+ +----+ +----+ +----+
  7. | 1 | | 2 | | 3 | | 4 | | 5 |
  8. +----+ +----+ +----+ +----+ +----+
  9. */



Teoretycznie masz 5 możliwości
1. Twój jest przed istniejącym
2. Zachodzi na początek istniejącego
3. Zawiera się w istniejącym
4. Zachodzi na koniec istniejącego
5. Jest później od istniejącego

Ale, tak na prawdę sprowadza się to do trzech przypadków:
1. Jest całkowicie przed
2-4. Koliduje
5. Jest całkowicie po

1. Sprawdzasz zwyczajnie czas zakończenia nowego <= czas rozpoczęcia istniejącego
5. Czas rozpoczęcia nowego >= czas zakończenia poprzedniego
2-4. Pozostałe
Pyton_000
Może nie kod i nie rozwiązanie ale problem bardzo podobny. Polecam przesłuchanie i zobaczenie jak ludzie sobie radzą smile.gif

https://www.youtube.com/watch?v=3Q_oYDQ2whs
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.