我必须首先告诉您,虽然我是一名经验丰富的rails开发人员,但我对PHP和原始SQL非常生疏。我正在尝试使用this tutorial和this 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
等
很明显,距离正在计算中,但我无法获取每个地址和位置名称。
我做错了什么?
谢谢!
答案 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";