3

重複の可能性:
mySQL select zipcodes within x km/miles within range of y

1 つ目は郵便番号とカテゴリ、2 つ目は郵便番号、緯度と経度の 2 つのテーブルがあります。今、私は検索したい...私の質問に移動する前にテーブル形式を聞いてください
Table1 (uk_data)
comp_post_code cat1 cat2



Table2 (uk_pc)
郵便番号 緯度 経度


今私はコストコードでcat1とcat2を検索したい...私が作った...ここにあります

SELECT * from uk_data where 
cat10 like :comp_post_code  AND (
cat1 like :cat OR
cat2 like :cat)

これにより、この郵便番号にある結果が得られますが、5つの鉱山と10マイルのエリアにあるアイテムを検索したいのですが、どうすればできますか?
郵便番号間の距離を計算する方法は知っていますが、コードは次のとおりです

function distance($lat1, $lon1, $lat2, $lon2, $unit) { 

  $theta = $lon1 - $lon2; 
  $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;
      }
}

しかし、5 マイルまたは 10 マイルで結果を得るために、表 2 のひよこにこれをループで取得する方法がわかりません...助けてください

4

1 に答える 1

0

同様の質問がここにあると思います。

よくわかりませんが、中にあるものPHPも似ていますGeokit gem of RoR

于 2012-12-30T08:56:38.940 に答える