Google Maps Store Finder查询未正确返回

时间:2011-05-18 01:00:04

标签: php javascript mysql google-maps

我必须首先告诉您,虽然我是一名经验丰富的rails开发人员,但我对PHP和原始SQL非常生疏。我正在尝试使用this tutorialthis tutorial构建商店查找器应用。我正在开会

这是我用于查询的代码(使用我自己的数据库列名)

$user_lat = $_GET["lat"];
$user_lng = $_GET["lng"];
$radius = $_GET["radius"];

$query = "SELECT 'Address','LocName','Latitude','Longitude', ( 3959 * acos( cos( radians($user_lat) ) * cos( radians( Latitude ) ) * cos( radians( Longitude ) - radians($user_lng) ) + sin( radians($user_lat) ) * sin( radians( Latitude ) ) ) ) AS distance FROM Locations ORDER BY distance";

我将结果返回(仅作为测试):

$result = mysql_query($query);
if (!$result) {
  die("Invalid query: " . mysql_error());
}

$num=mysql_numrows($result);

mysql_close();
?>
<table border="0" cellspacing="2" cellpadding="2">
<tr>
<th><font face="Arial, Helvetica, sans-serif">Name</font></th>
<th><font face="Arial, Helvetica, sans-serif">Distance</font></th>
<th><font face="Arial, Helvetica, sans-serif">Address</font></th>
</tr>

<?php
while ($row = mysql_fetch_assoc($result)) {
$f1=mysql_result($result,$i,"LocName");
$f2=mysql_result($result,$i,"distance");
$f3=mysql_result($result,$i,"Address");
?>

<tr>
<td><font face="Arial, Helvetica, sans-serif"><?php echo $f1; ?></font></td>
<td><font face="Arial, Helvetica, sans-serif"><?php echo $f2 ?></font></td>
<td><font face="Arial, Helvetica, sans-serif"><?php echo $f3; ?></font></td>
</tr>

<?php
$i++;
}
?>

但是当我离开时,我得到以下结果:findstore.php?lat = 33.98&amp; lng = -118.42

Name    Distance    Address
LocName     0.65415504532801    Address
LocName     0.65415504532801    Address
LocName     0.666819627384179   Address
LocName     0.923277344110443   Address
LocName     2.32751232712236    Address
LocName     2.33924574433009    Address

很明显,距离正在计算中,但我无法获取每个地址和位置名称。

我做错了什么?

谢谢!

1 个答案:

答案 0 :(得分:1)

尝试使用反引号替换查询中的单引号。

即:

$query = "SELECT `Address`,`LocName`,`Latitude`,`Longitude`, ( 3959 * acos( cos( radians($user_lat) ) * cos( radians( Latitude ) ) * cos( radians( Longitude ) - radians($user_lng) ) + sin( radians($user_lat) ) * sin( radians( Latitude ) ) ) ) AS distance FROM Locations ORDER BY distance";