Foros del Web » Programando para Internet » PHP »

Duda para averiguar fechas intermedias

Estas en el tema de Duda para averiguar fechas intermedias en el foro de PHP en Foros del Web. Hola! Tengo un problema que no le encuentro la vuelta. Tengo un calendario en PHP que muestra reservas de habitaciones por dia. El problema es ...
  #1 (permalink)  
Antiguo 26/05/2009, 09:20
Avatar de maxi_lance  
Fecha de Ingreso: julio-2006
Ubicación: Capital Federal
Mensajes: 220
Antigüedad: 17 años, 10 meses
Puntos: 2
Duda para averiguar fechas intermedias

Hola! Tengo un problema que no le encuentro la vuelta.
Tengo un calendario en PHP que muestra reservas de habitaciones por dia.

El problema es al modificar un tipo de habitacion de una reserva, ya que tengo que consultar a la base de datos si esta disponible en esa fecha el tipo de habitacion nuevo que estoy eligiendo.

Ejemplo:

id fechaReserva fechaReservaSalida tipoHabitacion
21 2009-05-07 2009-05-10 4
24 2009-05-09 2009-05-12 2

Si yo quiero modificar el id 21 a tipoHabitacion 2, no tendria que dejarme.
El tema es que no encuentro la consulta exacta para que me encuentre que entre el 2009-05-09 y el 2009-05-12 no puedo cambiar a 2 el tipoHabitacion

Una de las consultas que probe fue esta:

SELECT * FROM reservas WHERE fechaReserva < '2009-05-07' AND fechaReservaSalida < '2009-05-10' AND tipoHabitacion = 2

Pero mi gran problema es que no me doy idea de como podria tomar mediante PHP o Mysql las fechas intermedias.
  #2 (permalink)  
Antiguo 26/05/2009, 09:30
Avatar de martin0341  
Fecha de Ingreso: septiembre-2006
Ubicación: Rosario - Santa Fe
Mensajes: 296
Antigüedad: 17 años, 7 meses
Puntos: 8
Respuesta: Duda para averiguar fechas intermedias

a ver, si la consulta te devuelve un resultado es que esta ocupada, en cambio si no te devuelve nada podrias hacer la reserva.
No se si me explico?
  #3 (permalink)  
Antiguo 26/05/2009, 09:36
 
Fecha de Ingreso: octubre-2008
Mensajes: 71
Antigüedad: 15 años, 6 meses
Puntos: 0
Respuesta: Duda para averiguar fechas intermedias

tendrias que rescatar la fecha inicio y fecha fin desde mysql

despues buscarla usando php las fechas intermedias, ya que tampoco se me ocurre como en sql neto.

esto te puede ayudar: disculpa si hay falta de sintaxis no lo probe

Código &lt:
Ver original
  1. $FechaBuscar='2009-12-09';
  2. $FIni='2009-11-20';
  3. $FEnd='2009-12-24';
  4. $buf='';
  5. list($anio_i,$mes_i,$dia_i)=explode("-",$FIni);
  6. $i=1;
  7. $err=0;
  8. while(true){
  9.  
  10. $buf=date("Y-m-d",mktime(0,0,0,$mes_i,$dia_i+$i,$anio_i));
  11.  
  12. if($buf==$FEnd){
  13. $err=1;
  14. break 2;
  15. }
  16. elseif($buf==$FechaBuscar){
  17. echo "la fecha ${buf} esta dentro del rango :OO ",
  18. }
  19. $i++;
  20. }
  21. if($err==0){
  22. mysql_query ("update....$FechaBuscar");
  23.  
  24. }
  #4 (permalink)  
Antiguo 26/05/2009, 09:37
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años
Puntos: 1517
Respuesta: Duda para averiguar fechas intermedias

Algo así puedes hacer

Código PHP:
$fechaReserva "2009-05-07";
$fechaSalida "2009-05-10";

$fechaReserva2 "2009-05-09";
$fechaSalida2 "2009-05-12";

if(
$fechaReserva <= $fechaReserva2 && $fechaSalida >= $fechaReserva2){
    echo 
"Mensaje";
}
if(
$fechaReserva <= $fechaSalida2 && $fechaSalida >= $fechaSalida2){
    echo 
"Mensaje";


Tratalo y me dejas saber
  #5 (permalink)  
Antiguo 26/05/2009, 09:42
 
Fecha de Ingreso: octubre-2008
Mensajes: 71
Antigüedad: 15 años, 6 meses
Puntos: 0
Respuesta: Duda para averiguar fechas intermedias

estimado,

creo que php te lo tomaria como comparativa de textos y no de fechas.

saludos

Cita:
Iniciado por abimaelrc Ver Mensaje
Algo así puedes hacer

Código PHP:
$fechaReserva "2009-05-07";
$fechaSalida "2009-05-10";

$fechaReserva2 "2009-05-09";
$fechaSalida2 "2009-05-12";

if(
$fechaReserva <= $fechaReserva2 && $fechaSalida >= $fechaReserva2){
    echo 
"Mensaje";
}
if(
$fechaReserva <= $fechaSalida2 && $fechaSalida >= $fechaSalida2){
    echo 
"Mensaje";


Tratalo y me dejas saber
  #6 (permalink)  
Antiguo 26/05/2009, 10:57
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años
Puntos: 1517
Respuesta: Duda para averiguar fechas intermedias

Eso es así pero como quiera hace la funcion de lo que el pide.
  #7 (permalink)  
Antiguo 26/05/2009, 11:42
Avatar de maxi_lance  
Fecha de Ingreso: julio-2006
Ubicación: Capital Federal
Mensajes: 220
Antigüedad: 17 años, 10 meses
Puntos: 2
Respuesta: Duda para averiguar fechas intermedias

Estoy probando con lo que me dice abimaelrc, pero el problema que tengo es como averiguar que de acuerdo a las fechas que tengo para modificar el tipoHabitacion, 2009-05-07 y 2009-05-10, me encuentre que hay una reserva hecha entre el 2009-07-09 y el 2009-07-12 y entonces no me deje hacerlo.
No encuentro el php o la consulta mysql que me traiga la fecha del 2009-05-07 y 2009-05-10.

Una vez que averigue esta consulta o php ahi si podria comparar las 4 fechas.

Última edición por maxi_lance; 26/05/2009 a las 12:10
  #8 (permalink)  
Antiguo 30/05/2009, 09:00
Avatar de maxi_lance  
Fecha de Ingreso: julio-2006
Ubicación: Capital Federal
Mensajes: 220
Antigüedad: 17 años, 10 meses
Puntos: 2
Respuesta: Duda para averiguar fechas intermedias

Les paso abajo el codigo de como lo solucione, gracias al aporte de los users que me respondieron aqui...

Código PHP:
echo fsalida($_POST['fechaReserva']) . "<br>";
echo 
fsalida($_POST['fechaReservaSalida']) . "<br>";

list(
$anio,$mes,$dia)=explode("-",fsalida($_POST['fechaReserva']));
list(
$anio2,$mes2,$dia2)=explode("-",fsalida($_POST["fechaReservaSalida"]));

$in mktime(0,0,0,$mes,$dia,$anio);
$outmktime(0,0,0,$mes2,$dia2,$anio2);
$resta $out $in
$total round($resta/86400);  
        
$i $err 0;
$cambiarTipoHabitacion TipoHabitacionID ($_POST['tipoHabitacion']);
        
while (
$i <= $total) {

list(
$anio,$mes,$dia)=explode("-",fsalida($_POST['fechaReserva']));
$buf=date("Y-m-d",mktime(0,0,0,$mes,$dia+$i,$anio));
$sqlVer "SELECT * FROM  reservas WHERE fechaReservaSalida = '" $buf  "' AND tipoHabitacion = " $cambiarTipoHabitacion " AND nrohabitacion = " $_POST["numero"] . " AND hotel = " PermisoUsuarios ($_SESSION['admin']['id']) ;
$resultVer mysql_query($sqlVer);
$totalVer mysql_num_rows ($resultVer);

if (
$totalVer 0) {
$err $err ;
}
$i++;

}

if (
$err 0) {
echo 
"No se puede ";
break;
} else {
INSERTAR

  #9 (permalink)  
Antiguo 30/05/2009, 09:11
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años
Puntos: 1517
Respuesta: Duda para averiguar fechas intermedias

Gracias por compartir el codigo
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 20:42.