Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [mySQL] sprawdzanie dat rezerwacji, beetween
pionas
post 5.06.2013, 19:08:40
Post #1





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 25.03.2009
Skąd: Pionki

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


Witam,

mam skypt, w którym dokonuję rezerwaci sali, niestety mam problem ze sprawdzeniem czy dana sala jest już zarezerwowana czy nie.
  1. SELECT * FROM terminarz WHERE sala='{$sala}' AND ((start BETWEEN '{$start}' AND '{$end}') OR (end BETWEEN '{$start}' AND '{$end}')) ORDER BY id DESC

powyższe zapytanie działa wtedy kiedy chcemy rezerwować salę przy starcie lub endzie.

A co gdy chcę zarezwować salę w godzinach których owa sala jest zajęta?

PRZYKŁAD:
Sala | Start | End
1 | 12:00 | 15:00
2 | 08:00 | 15:00

Jeśli dam:
{$start} = 10:00
{$end} = 16:00
{$sala} = 1
to działa, tzn. nie zarezerwuje mi sali i wyskoczy komunikat o rezerwacji

Jeśli dam:
{$start} = 13:00
{$end} = 14:00
{$sala} = 1
to nie działa, tzn. zarezerwuje mi salę...

Jak poprawić takie zapytanie?
Samo sql wystarczy czy to trzeba połączyć z PHP?


--------------------
Organizujesz konkurs? Chcesz coś wygrać? Wejdź na www.e-Konkursy.info :)
Go to the top of the page
+Quote Post
pmir13
post 5.06.2013, 19:50:16
Post #2





Grupa: Zarejestrowani
Postów: 282
Pomógł: 89
Dołączył: 12.04.2011

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


W swoim warunku WHERE rozważasz dwa z trzech możliwych przypadków, w których sala jest zablokowana.
Jedyne co trzeba zrobić to dodać ten trzeci:

  1. .. OR start < '{$start}' AND end > '{$end}' ...


Ten post edytował pmir13 5.06.2013, 19:50:47
Go to the top of the page
+Quote Post
pionas
post 5.06.2013, 20:31:50
Post #3





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 25.03.2009
Skąd: Pionki

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


Właśnie na tym warunku nie działa.
Dodałem:
  1. ... OR (end>'{$end}' AND start<'{$end}') ...

i chyba działa...


--------------------
Organizujesz konkurs? Chcesz coś wygrać? Wejdź na www.e-Konkursy.info :)
Go to the top of the page
+Quote Post
mmmmmmm
post 5.06.2013, 21:13:52
Post #4





Grupa: Zarejestrowani
Postów: 1 421
Pomógł: 310
Dołączył: 18.04.2012

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


http://forum.php.pl/index.php?s=&showt...t&p=1048320
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 7.07.2025 - 00:50