首頁 >資料庫 >mysql教程 >如何在 PHP 中計算兩個郵遞區號之間的距離?

如何在 PHP 中計算兩個郵遞區號之間的距離?

DDD
DDD原創
2024-11-02 11:44:30434瀏覽

How to Calculate the Distance Between Two Zip Codes in PHP?

用PHP 計算郵遞區號之間的距離

計算兩個郵遞區號之間的距離需要存取包含每個郵遞區號的緯度和經度資訊的資料庫代碼。本問題探討如何使用 MySQL 表中的資料計算此距離。

建議的解法利用 PHP 函數來計算給定兩點之間的距離緯度和經度。程式碼如下:

<code class="php">function calc_distance($point1, $point2)
{
    // Constants
    $radius       = 3958;      // Earth's radius (miles)
    $deg_per_rad  = 57.29578;  // Number of degrees/radian (for conversion)

    $distance = ($radius * pi() * sqrt(
        ($point1['lat'] - $point2['lat'])
        * ($point1['lat'] - $point2['lat'])
        + cos($point1['lat'] / $deg_per_rad)  // Convert to radians for cos()
        * cos($point2['lat'] / $deg_per_rad)  // Convert to radians for cos()
        * ($point1['long'] - $point2['long'])
        * ($point1['long'] - $point2['long'])
    ) / 180);

    return $distance;  // Returned using the units used for $radius.
}</code>

USAGE

此函數需要兩個資料點($point1 和$point2)作為參數,每個資料點包含一個點的緯度和經度郵遞區號。返回的距離將採用與提供的半徑常數相同的單位(在本例中為英里)。

以上是如何在 PHP 中計算兩個郵遞區號之間的距離?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn