重複の可能性:
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 のひよこにこれをループで取得する方法がわかりません...助けてください