我在堆栈上找到了这个问题-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/

10-12 01:24
查看更多