0

住所のデータベースがあり、ユーザーが地図上にピンポイントをドロップし、そのポイント周辺の走行距離に基づいて地域を定義できるようにしたいと考えています。そのユーザー定義領域でデータベースを検索する方法があるかどうか疑問に思っていました。

4

2 に答える 2

0

キロメートルを使用する国際システムの場合、スクリプトの一部を次のように置き換えます。

6371 * acos( cos( radians(LATITUDE1) ) * cos( radians( LATITUDE2 ) ) * cos( radians( LONGITUDE1 ) - radians(LONGITUDE2) ) + sin( radians(LATITUDE1) ) * sin( radians( lat ) ) ) AS DISTANCE

ソース: http://www.codecodex.com/wiki/Calculate_Distance_Between_Two_Points_on_a_Globe#MySQL

于 2012-02-06T01:37:21.477 に答える
0

ピンドロップの経度と緯度の座標を取得し、そのデータをサーバーに送信して、このページにリストされているクエリを使用して結果を返すことができるはずです: http://code.google.com/apis/maps/articles /phpsqlsearch.html

SELECT id, ( 3959 * acos( cos( radians(37) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians(-122) ) + sin( radians(37) ) * sin( radians( lat ) ) ) ) AS distance FROM markers HAVING distance < 25 ORDER BY distance LIMIT 0 , 20;

住所を経度と緯度にもジオコーディングし、各住所とともに保存する必要があります。これは、データベース内の住所の経度と緯度をスクレイピングするために使用した正確なコードです。

  /* Geocode Address
  /***********************/
  $query = $db->query("SELECT * FROM wholesale_clients WHERE hq_id IN (SELECT owner_id FROM storelocator)");
  while($info = $query->fetch_array()) {
    $address = str_replace(' ', '+', $info['address_1'] . ' ' . $info['address_2'] . ' ' . $info['suburb'] . ' ' . $info['state'] . ' ' . $info['zip'] . ' Australia');
    $file = file_get_contents('https://maps.googleapis.com/maps/api/geocode/xml?address='.$address.'&sensor=false');
    $file = xml2array($file);
    $lat = $file['GeocodeResponse']['result']['geometry']['location']['lat'];
    $lng = $file['GeocodeResponse']['result']['geometry']['location']['lng'];
    //echo $info['hq_id'] . ' ' . $lat . ' ' . $lng . '<br />';
    if(!empty($lat) && !empty($lng)) {
    $db->query("UPDATE `storelocator` SET `lat` = '" . $lat . "', `lng` = '" . $lng . "', `updated` = 1 WHERE `owner_id` = '" . $info['hq_id'] . "'");
    }
  }

  /***********************/

XML2array 関数: http://www.bin-co.com/php/scripts/xml2array/

于 2011-09-07T14:15:10.210 に答える