Foros del Web » Programando para Internet » PHP »

Error en código de cálculo de distancias

Estas en el tema de Error en código de cálculo de distancias en el foro de PHP en Foros del Web. Tengo el siguiente código para el cálculo de distancias entre dos puntos: include_once('../getBoundaries.php'); $box = getBoundaries($latitud, $longitud, $distanciausuario); Función para acotar la distancia entre dos ...
  #1 (permalink)  
Antiguo 10/12/2015, 05:06
 
Fecha de Ingreso: mayo-2014
Mensajes: 45
Antigüedad: 9 años, 11 meses
Puntos: 0
Error en código de cálculo de distancias

Tengo el siguiente código para el cálculo de distancias entre dos puntos:
include_once('../getBoundaries.php');
$box = getBoundaries($latitud, $longitud, $distanciausuario);
Función para acotar la distancia entre dos puntos.
Y la consulta:
$result = mysql_query('SELECT id_cliente, nombre, tipo, precio, icono1, localidad, (6371 * ACOS(
SIN(RADIANS(lat))
* SIN(RADIANS(' . $latitud . '))
+ COS(RADIANS(lng - ' . $longitud . '))
* COS(RADIANS(lat))
* COS(RADIANS(' . $latitud . '))
)
) AS distance
FROM restauracion
WHERE (lat BETWEEN ' . $box['min_lat']. ' AND ' . $box['max_lat'] . ')
AND (lng BETWEEN ' . $box['min_lng']. ' AND ' . $box['max_lng']. ')
HAVING distance < ' . $distanciausuario . '
ORDER BY distance ASC ');
Hasta ahí funciona bien, el problema es cuando añado otra variable en la cláusula WHERE que en realidad me filtra por un tipo de establecimiento: tipo IN('$tipos_trim'), quedando de la siguiente manera:

WHERE tipo IN('$tipos_trim')
AND (lat BETWEEN ' . $box['min_lat']. ' AND ' . $box['max_lat'] . ')
AND (lng BETWEEN ' . $box['min_lng']. ' AND ' . $box['max_lng']. ')
HAVING distance < ' . $distanciausuario . '
ORDER BY distance ASC ');
Que me da error en php.
En realidad son dos preguntas, una porqué utiliza ‘ . $variable . ‘ y no ‘$variable’ y dos, porqué me da error en el código cuando añado en la claúsula WHERE tipo IN('$tipos_trim').
Gracias de antemano a quién me pueda ayudar, pues no doy con ello.
  #2 (permalink)  
Antiguo 10/12/2015, 06:51
Avatar de chronos682  
Fecha de Ingreso: febrero-2004
Ubicación: Tunja - Boyacá - Colombia
Mensajes: 627
Antigüedad: 20 años, 2 meses
Puntos: 69
Respuesta: Error en código de cálculo de distancias

En primer lugar, de cualquiera de las dos formas que mencionas debería funcionar, respecto a la consulta sql deberías poner el error que te muestra la página y además deberías colocar la pregunta en el foro de bases de datos, porque el problema está en la sintaxis SQL y no en el código php.
__________________
Si te gustó la respuesta dale +1

HERNÁN G. SIABATO M.
[email protected]
  #3 (permalink)  
Antiguo 10/12/2015, 07:02
 
Fecha de Ingreso: mayo-2014
Mensajes: 45
Antigüedad: 9 años, 11 meses
Puntos: 0
Respuesta: Error en código de cálculo de distancias

El error que da es:
Parse error: syntax error, unexpected T_VARIABLE in /home/guia/public_html/AccesoDatos/phpconsult/apartados/tiposComer.php on line 39
que corresponde con:
WHERE tipo IN('$tipos_trim')

En cuanto a la pregunta en el foro disculpa, ahora la cambio.
Gracias de nuevo.
  #4 (permalink)  
Antiguo 10/12/2015, 08:18
Avatar de chronos682  
Fecha de Ingreso: febrero-2004
Ubicación: Tunja - Boyacá - Colombia
Mensajes: 627
Antigüedad: 20 años, 2 meses
Puntos: 69
Respuesta: Error en código de cálculo de distancias

Ese tipo de error si es de php y es porque estás omitiendo alguna comilla o el punto y coma final o algún paréntesis en la consulta. Si puedes coloca el código tal cual como haces la llamada.
__________________
Si te gustó la respuesta dale +1

HERNÁN G. SIABATO M.
[email protected]
  #5 (permalink)  
Antiguo 10/12/2015, 08:36
 
Fecha de Ingreso: mayo-2014
Mensajes: 45
Antigüedad: 9 años, 11 meses
Puntos: 0
Respuesta: Error en código de cálculo de distancias

El tema es que si filtro por tipo:
$result = mysql_query("select id_cliente, nombre, tipo, precio, icono1, localidad FROM restauracion WHERE tipo IN('$tipos_trim')");
Funciona perfectamente.
Si filtro por distancia:
$result = mysql_query('SELECT id_cliente, nombre, tipo, precio, icono1, localidad, (6371 * ACOS(
SIN(RADIANS(lat))
* SIN(RADIANS(' . $latitud . '))
+ COS(RADIANS(lng - ' . $longitud . '))
* COS(RADIANS(lat))
* COS(RADIANS(' . $latitud . '))
)
) AS distance
FROM restauracion
WHERE (lat BETWEEN ' . $box['min_lat']. ' AND ' . $box['max_lat'] . ')
AND (lng BETWEEN ' . $box['min_lng']. ' AND ' . $box['max_lng']. ')
HAVING distance < ' . $distanciausuario . '
ORDER BY distance ASC');
Funciona perfectamente.
Pero si filtro por tipo y distancia:
$result = mysql_query('SELECT id_cliente, nombre, tipo, precio, icono1, localidad, (6371 * ACOS(
SIN(RADIANS(lat))
* SIN(RADIANS(' . $latitud . '))
+ COS(RADIANS(lng - ' . $longitud . '))
* COS(RADIANS(lat))
* COS(RADIANS(' . $latitud . '))
)
) AS distance
FROM restauracion
WHERE tipo IN('$tipos_trim')
AND (lat BETWEEN ' . $box['min_lat']. ' AND ' . $box['max_lat'] . ')
AND (lng BETWEEN ' . $box['min_lng']. ' AND ' . $box['max_lng']. ')
HAVING distance < ' . $distanciausuario . '
ORDER BY distance ASC');
Da error en la límea WHERE tipo IN('$tipos_trim') y en la ORDER BY distance ASC'); en Dreamweaver.
  #6 (permalink)  
Antiguo 10/12/2015, 08:46
Avatar de chronos682  
Fecha de Ingreso: febrero-2004
Ubicación: Tunja - Boyacá - Colombia
Mensajes: 627
Antigüedad: 20 años, 2 meses
Puntos: 69
Respuesta: Error en código de cálculo de distancias

Ya revisaste que no falten ni sobren paréntesis y que estés ysando las comillas dobles y simples adecuadamente?
__________________
Si te gustó la respuesta dale +1

HERNÁN G. SIABATO M.
[email protected]
  #7 (permalink)  
Antiguo 10/12/2015, 14:37
 
Fecha de Ingreso: mayo-2014
Mensajes: 45
Antigüedad: 9 años, 11 meses
Puntos: 0
Respuesta: Error en código de cálculo de distancias

He cambiado WHERE tipo IN ('$tipos_trim') por WHERE tipo IN ("$tipos_trim") y al poner comillas dobles ha dejado de dar error en Dreamweaver. Pero al ejecutar la aplicación me da un error_log con el siguiente mensaje:
[10-Dec-2015 20:29:27 UTC] PHP Warning: Module 'zip' already loaded in Unknown on line 0

Etiquetas: mysql, select, variable
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 22:45.