我在堆栈上找到了这个问题-Measuring the distance between two coordinates in PHP
答案似乎在很多方面对我来说都是完美的,但我遇到了一个问题。我在设计CRM的过程中,希望有一个邮政编码半径搜索选项。我的问题是如何针对此查询传递可能有1,000条记录的内容并以HTML显示结果?
最佳答案
因此,我通过结合一些来源找到了一个解决方案(3959代表英里,6371代表千米)。我在下面提供了一个PHP文件和HTML表,以防万一其他人遇到此问题。
首先,您可以从这里获取所需的数据:
https://www.freemaptools.com/download-uk-postcode-lat-lng.htm
我建议您使用该站点创建一个基本的MySQL表并导入数据,但是请注意,这将需要一些时间!同样,在运行查询以删除所有空格之前或之后,AA11 1AA变为AA111AA,这将使表单验证变得更加简单。
此迷你演练使用该链接中的数据和表构造。
首先,您将需要一个用户输入表单,该表单应如下所示:
<form action="" method="POST">
<table>
<tr>
<td>Distance:</td>
<td><input type="number" id="distance" name="distance" required></td>
</tr>
<tr>
<td>Miles:<br>Kilometres:</td>
<td><input type="radio" id="unit" name="unit" value="3959" checked><br><input type="radio" id="unit" name="unit" value="6371"></td>
</tr>
<tr>
<td>Postcode:</td>
<td><input type="text" id="postcode" name="postcode" required></td>
</tr>
<tr>
<td></td>
<td><input type="submit" id="submit" name="submit" value="Submit"></td>
</tr>
</table>
</form>
此表单提交到同一页面,因此在您的.php文件中,您需要包括以下代码以将邮政编码转换为long / lat值:
<?php include 'credentials.php';
$distance = $_POST['distance'];
$unit = $_POST['unit'];
$postcode = str_replace(' ','',$_POST['postcode']);
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql = "SELECT latitude, longitude FROM postcodelatlng WHERE postcode LIKE '$postcode'";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
$latitude = $row['latitude'];
$longitude = $row['longitude'];
}
} else {
echo "Postcode not found";
}
$conn->close();
?>
确保您有一个certificate.php文件,以提供数据库的连接详细信息,以使其正常工作。
然后直接在这个php脚本的下面放置第二个脚本,它将返回特定半径内的所有邮政编码。然后,您可以修改此脚本以满足您的需求。我将亲自将此脚本传递给另一个小得多的表,以检查CRM上是否在某个半径范围内的任何记录,但是就目前和出于演示目的而言,请保持简单!
<?php
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql = "SELECT *,
($unit * acos( cos( radians($latitude) ) * cos( radians(latitude) ) * cos( radians(longitude) - radians($longitude)) + sin(radians($latitude)) * sin(radians(latitude)) ))
as distance
FROM postcodelatlng
HAVING distance < $distance";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
echo "" . $row['postcode']. "<br>";
}
} else {
echo "<br>0 results";
}
$conn->close();
?>
主要感谢这篇文章的使用:
Fastest Way to Find Distance Between Two Lat/Long Points
关于php - 长/短距离查询整个数据库,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46795262/