私は趣味のプロジェクトとして、会社のウェブサイトを作り始めました。私はウェブサイトのための複雑なコードを作成することはあまり進んでいないが、私はそれを試してみたかった。mysqlでHaversine数式を高速化するには?
オランダの郵便番号データベースが471000件以上あります。私はhaversineの式を使って、どの郵便番号が半径13キロ以内かを調べ、この結果に郵便番号を持つデータベースからすべてのユーザーを選択します。しかし、すべての結果をロードするには6秒かかります。このプロセスをどのようにスピードアップできますか?以下
コード:
$finder = $mysqli->query("SELECT lat, lng FROM postcodetabel WHERE postcode = '$s' OR plaats = '$s'");
$finder1 = mysqli_fetch_assoc($finder);
$latitude = $finder1['lat'];
$longitude = $finder1['lng'];
$query = $mysqli->query("SELECT postcode, (
6371 * acos (
cos (radians('$latitude'))
* cos(radians(lat))
* cos(radians(lng) - radians('$longitude'))
+ sin (radians('$latitude'))
* sin(radians(lat))
)
) AS distance
FROM postcodetabel
HAVING distance < 12
ORDER BY distance ASC");
$quertie = $mysqli->query("SELECT bigav, id, naam, email, bedrijfsnaam, telnummer FROM gebruikers WHERE postcode = '$postcode' AND status = 1 AND soort LIKE '%" . $soort . "%'");
while($quertie2 = mysqli_fetch_assoc($quertie)) { echo '
<div class="kapper">
<div class="kapperfoto"><img src="/vluggeknipt/ondernemer/pagina/uploads/'.$quertie2['bigav'].'" style="width:100px;height:100px;"></div>
<div class="boektekst">
<font class="headingkap"><strong><a href="?page=profiel&id='.$quertie2['id'].'">Naar profiel »</a></strong></font><br/>
</div>
<div class="kappertext">
<font class="headingkap"><a href="?page=profiel&id='.$quertie2['id'].'"><strong>'.$quertie2['naam'].'</strong></a></font><br/>
<i class="mobhide">'.$quertie2['email'].' - '.$quertie2['telnummer'].'</i><br/>
<i class="mobhide">'.$quertie2['bedrijfsnaam'].'</i>
</div></div><br/>
'; }
事前に感謝します!
偉大な答え!この方法が合理的に正確である距離の上限を示すことができますか?言って、正解の5%以内? – richplane