设置值时出现PHP查询问题?

时间:2015-05-08 14:43:03

标签: php mysql sql mamp haversine

快速提问。我有一个适用于我的数据库的SQL查询。但是,我确定如何在我的PHP文件中设置参数,以便它可以与我的查询一起使用?

任何想法?我在使用php方面的Set参数方面遇到了麻烦,并使我的查询工作。

<?php

/*
 * Following code will list all the products
 */

// array for JSON response
$response = array();

// include db connect class
require_once __DIR__ . '/db_connect.php';

// connecting to db
$db = new DB_CONNECT();

set $orig_lat=32.42; 
set $orig_long=-23.550; 
set $bounding_distance=1;

// get all products from products table
$result = mysql_query(" SELECT * ,((ACOS(SIN($orig_lat * PI() / 180) * SIN(`latitude` * PI() /
180) + COS($orig_lat * PI() / 180) * COS(`latitude` * PI() / 180) *
COS(($orig_long - `longitude`) * PI() / 180)) * 180 / PI()) * 60 *
1.1515) AS `distance` FROM `Location` WHERE ( `latitude` BETWEEN
($orig_lat - $bounding_distance) AND ($orig_lat + $bounding_distance)
AND `longitude` BETWEEN ($orig_long - $bounding_distance) AND
($orig_long + $bounding_distance) ) ORDER BY `distance` ASC limit 1") or die(mysql_error()); 

// check for empty result
if (mysql_num_rows($result) > 0) {
    // looping through all results
    // products node
    $response["Location"] = array();

    while ($row = mysql_fetch_array($result)) {
        // temp user array
       $Location = array();
       $Location["id"] = $row["id"];
       $Location["latitude"] = $row["latitude"];
       $Location["longitude"] = $row["longitude"];



        // push single product into final response array
        array_push($response["Location"], $Location);
    }
    // success
    $response["success"] = 1;

    // echoing JSON response
    echo json_encode($response);
} else {
    // no products found
    $response["success"] = 0;
    $response["message"] = "No Profiles found";

    // echo no users JSON
    echo json_encode($response);
}
?>

1 个答案:

答案 0 :(得分:0)

这是一个简单的语法问题...与查询对应的值未被很好地记录。在PHP文件中,您无法使用$编写set和声明变量。

原件:

set $orig_lat=32.42; 
set $orig_long=-23.550; 
set $bounding_distance=1;

解决方案:

$orig_lat=32.42; 
$orig_long=-23.550; 
$bounding_distance=1;