Foros del Web » Programando para Internet » PHP »

consulta de diferentes rangos de fechas días y precios

Estas en el tema de consulta de diferentes rangos de fechas días y precios en el foro de PHP en Foros del Web. Buenas tengo una consulta complicada, a ver si alguien me puede brindar algo de ayuda. Tengo esta tabla: -id_temporada (int) -TipoHab. (String) – Enlaza con ...
  #1 (permalink)  
Antiguo 01/06/2015, 16:16
Avatar de midpunto  
Fecha de Ingreso: enero-2004
Ubicación: España Palma de mallorca
Mensajes: 118
Antigüedad: 20 años, 3 meses
Puntos: 0
consulta de diferentes rangos de fechas días y precios

Buenas tengo una consulta complicada, a ver si alguien me puede brindar algo de ayuda.
Tengo esta tabla:
-id_temporada (int)
-TipoHab. (String) – Enlaza con fichero TIPOHAB.
-TipoReg. (String) – Enlaza con fichero TIPOREG.
-DesdeFecha ( Date ) – Fecha inicio temporada.
-HastaFecha ( Date ) – Fecha Fin Temporada.
-PrecioAdulto ( Float ) – Precio 1er Adulto.
-PrecioAdulto2 ( Float ) – Precio 2º Adulto.
-Precio Adulto3 ( Float ) – Precio 3er Adulto.
-Precio Adulto4 ( Float ) – Precio 4º Adulto.
-Precio Nino1 ( Float ) – Precio 1er Niño.
-Precio Nino2 ( Float ) – Precio 2º Niño.

y tengo un formulario que envía los siguientes datos para buscar entre temporadas:
-fecha inicio
-fecha fin
-adultos
-niños

el caso es que necesito hacer una consulta para que me arroje un listado con diferentes tipos de habitaciones según coincidencias entre fechas y arrojar los precios según la temporada, se puede dar el caso que la fechainicio pertenezca a una temporada y la segunda fecha a otra temporada o no, en todo caso hay que recorrer el periodo al que se corresponda y arrojar los resultados y sumar los precios adulto o niño sea de una, o de varias temporadas.

La consulta con la que he intentado es la siguiente:

$START='2012-06-10';
$END='2012-08-20';
mysql_select_db($database_conecta, $conecta);
$query_Recordset1 = "SELECT SUM((DATEDIFF(IF(fechafin>=$END,$END,fechafin), IF(fechainicio<=$START,$START,fechainicio) )+1)*precioadulto ) AS TOTAL_SUM FROM temporadas WHERE fechainicio<=$END AND fechafin>=$START";

Pero no termina de ir bien, gracias de antemano.
  #2 (permalink)  
Antiguo 01/06/2015, 17:14
Avatar de midpunto  
Fecha de Ingreso: enero-2004
Ubicación: España Palma de mallorca
Mensajes: 118
Antigüedad: 20 años, 3 meses
Puntos: 0
Respuesta: consulta de diferentes rangos de fechas días y precios

Ok por si a alguien le sirve he llegado a esta solución:

$fechainicio='2010-09-10';
$fechafin='2010-11-2';
mysql_select_db($database_conecta, $conecta);
$query_Recordset1 = "SELECT * FROM temporadas WHERE (temporadas.fechainicio BETWEEN '$fechainicio' AND '$fechafin')
OR (temporadas.fechafin BETWEEN '$fechainicio' AND '$fechafin')
OR (temporadas.fechainicio <= '$fechainicio' AND temporadas.fechafin >= '$fechafin')";

Pero... ahora el tema esta en contar los días ya que si la fechas estan entre temporadas distintas los precios por persona cambian, solamente en este caso,.. alguna idea?
  #3 (permalink)  
Antiguo 02/06/2015, 04:51
Avatar de zalito12  
Fecha de Ingreso: noviembre-2011
Ubicación: Coruña, España
Mensajes: 430
Antigüedad: 12 años, 5 meses
Puntos: 67
Respuesta: consulta de diferentes rangos de fechas días y precios

Suponiendo que tu consulta esté bien, es que es mucho lío y ahora no la puedo probar.

Lo primero, creo que deberías ordenar los resultados por fecha de inicio creciente, partiendo de esa base, si lo piensas pueden sucerder 2 casos.
1. Sólo obtienes un resultado, la estancia está contenida en una temporada, la duración es la resta de las fechas elegidas.
2.Obtienes más de una temporada. En este caso, la problemática está en los extremos (en la primera y últimas temporadas de la consulta), puesto que el resto están contenidas totalmente entre las fechas elegidas por el usuario y puedes calcular su duración fácilmente con los datos de tus tablas.

Así que, para calcular el tiempo de la estancia de los extremos es fácil.
-Para la primera temporada, sería fecha de fin de la temporada - fecha de inicio del usuario
-Para la última temporada puedes mirar obtenerlo como la resta del total menos lo que llevas calculado o, fecha de fin del usuario - fecha de inicio de la temporada.

Para operar con fechas lo puedes hacer en php con datediff por ejemplo, o puedes aprovechar la consulta para que calcule esos datos y tú recurrirás a ellos cuando los necesites.
http://php.net/manual/es/datetime.diff.php
http://dev.mysql.com/doc/refman/5.6/...functions.html
__________________
Dicen que las personas piensan en su lengua materna, yo lo hago en PHP
  #4 (permalink)  
Antiguo 02/06/2015, 05:35
Avatar de midpunto  
Fecha de Ingreso: enero-2004
Ubicación: España Palma de mallorca
Mensajes: 118
Antigüedad: 20 años, 3 meses
Puntos: 0
Respuesta: consulta de diferentes rangos de fechas días y precios

Ante todo, gracias por tu respuesta, tu explicación esta muy clara. tratare de implementar la solución y vuelvo a escribir.
un saludo.

Etiquetas: fecha, formulario, mysql, precios, rangos, select, tabla
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 08:30.