按用户距离过滤数据库查询

时间:2015-07-14 06:16:22

标签: php mysql

我有一个用户可以搜索的事件和活动数据库。我希望用户能够过滤,例如只有50公里范围内的活动和事件(lol km #canada)。显然,每个用户的距离都会发生变化。

我已经有一个基于纬度和经度计算距离的脚本并显示它。我无法弄清楚如何只显示x km内的活动和事件。

不确定我应该发布什么代码,但可以发布所需的任何内容。

//MySQLi results query
$query= "SELECT id,name FROM activity WHERE active =1".$typequery.$eventtypequery.$catquery.$datequery.$keywordsquery." ORDER BY $orderby $order LIMIT $start_from,$perpage";

//Count query
$count = $mysqli->query("SELECT COUNT(*) FROM `activity` WHERE active=1".$typequery.$eventtypequery.$catquery.$datequery.$keywordsquery."");

$row = $count->fetch_row();

$total_records = $row[0];
$total_pages = ceil ($total_records /$perpage);

if (isset($page)&&($total_pages>1)) {$nextpage = $page+1;} else {$nextpage=0;}

if ($page>1) {$prevpage=$page-1;} else {$prevpage=0;}

$result=$mysqli->query($query);

function distance($lat1, $lon1, $lat2, $lon2, $unit) {
$theta = $lon1 - $lon2;
$unit="K";
$dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) +  cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta));
  $dist = acos($dist);
  $dist = rad2deg($dist);
  $miles = $dist * 60 * 1.1515;
  $unit = strtoupper($unit);

  if ($unit == "K") {
    return ($miles * 1.609344);
  } else if ($unit == "N") {
      return ($miles * 0.8684);
    } else {
        return $miles;
      }
}

1 个答案:

答案 0 :(得分:1)

这是我用远距离查询东西的方式,只需输入你的用户的$ LONG和$ LAT,你就可以获得与该用户关系密切的东西(编辑HAVING,无论你想要拥有它)

//so for example you will have 1 user with 
$lat = <something>;
$long = <something>;

SELECT <some other info you want to select>, 
((ACOS(SIN($lat * PI() / 180) * SIN($lat * PI() / 180) + COS($lat * PI() / 180) * COS($lat * PI() / 180) * COS(($long - <table>.longitude) * PI() / 180)) * 180 / PI()) * 60 * 1.1515) AS distance 
FROM <your table>
WHERE <maybe some filters here?>
HAVING distance<=10000
ORDER BY distance = '' DESC, distance ASC