作为一个爱好项目,我开始为一家公司制作一个网站。我在制作复杂的网站代码方面并不是很先进,但我想尝试一下。如何加快MySQL中的Haversine公式?
我有一个荷兰邮政编码数据库,其中有超过471000条记录。我使用haversine公式来查找哪些邮政编码位于13 km的半径范围内,然后从数据库中选择每个用户在此结果中具有邮政编码。但公式需要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