亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

尋找兩個拉長點之間距離的最快方法

尋找兩個拉長點之間距離的最快方法

心有法竹 2019-06-04 15:39:25
尋找兩個拉長點之間距離的最快方法我目前在MySQL數據庫中有將近100萬個位置,所有位置都有經度和緯度信息。我試圖通過查詢找到一個點和許多其他點之間的距離。它沒有我想要的那么快,尤其是每秒有100多個點擊率。是否有一個更快的查詢,或者可能是一個更快的系統,而不是MySQL呢?我使用這個查詢:SELECT    name,     ( 3959 * acos( cos( radians(42.290763) ) * cos( radians( locations.lat ) )     * cos( radians(locations.lng) - radians(-71.35368)) + sin(radians(42.290763))     * sin( radians(locations.lat)))) AS distance  FROM locations  WHERE active = 1 HAVING distance < 10 ORDER BY distance;注:所提供的距離為邁爾斯..如果你需要公里,使用6371而不是3959.
查看完整描述

3 回答

?
翻閱古今

TA貢獻1780條經驗 獲得超5個贊

  • 使用Point值.的值Geometry中的數據類型MyISAM桌子。截至MySQL 5.7.5,InnoDB表現在也支持SPATIAL指數。

  • 創建一個SPATIAL這些點的索引

  • 使用MBRContains()若要查找值,請執行以下操作:

    SELECT  *FROM    tableWHERE   MBRContains(LineFromText(CONCAT(
            '('
            , @lon + 10 / ( 111.1 / cos(RADIANS(@lon)))
            , ' '
            , @lat + 10 / 111.1
            , ','
            , @lon - 10 / ( 111.1 / cos(RADIANS(@lat)))
            , ' '
            , @lat - 10 / 111.1 
            , ')' )
            ,mypoint)

,或者,在MySQL 5.1及以上:

    SELECT  *
    FROM    table
    WHERE   MBRContains                    (
                    LineString                            (
                            Point (
                                    @lon + 10 / ( 111.1 / COS(RADIANS(@lat))),
                                    @lat + 10 / 111.1
                                  ),
                            Point (
                                    @lon - 10 / ( 111.1 / COS(RADIANS(@lat))),
                                    @lat - 10 / 111.1
                                  ) 
                            ),
                    mypoint                    )

這將在方框內大致選擇所有點。(@lat +/- 10 km, @lon +/- 10km).

這實際上不是一個盒子,而是一個球形矩形:球面的緯度和經度界段。這可能與弗蘭茲·約瑟夫·蘭德但在大多數有人居住的地方都離它很近。

  • 應用額外的過濾來選擇圓圈內的所有東西(而不是正方形)

  • 可能對大圓距離(大距離)應用額外的精細過濾。


查看完整回答
反對 回復 2019-06-04
?
慕少森

TA貢獻2019條經驗 獲得超9個贊

請查看這個演示文稿,以獲得一個好的答案?;旧?,它顯示了注釋中顯示的兩種不同的方法,并詳細解釋了為什么/什么時候應該使用其中一種,以及為什么“框中”的計算會非常有趣。

用MySQL進行地理距離搜索


查看完整回答
反對 回復 2019-06-04
  • 3 回答
  • 0 關注
  • 540 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號