MongoDB的地理位置索引


背景

我們平常打開一些App的時候,經常有一個“查詢周邊景點”的功能,如我在高德里面就查詢到了附近的景點。

這種計算如果通過普通的關系型數據庫,那對服務器和數據庫的性能要求就太高了。

我們可以通過MongoDB自帶的地址位置索引來實現。

如何使用
前期准備:插入數據
我們先插入四條數據,即店鋪的類型,名稱和地理位置。注意地理位置的第一個數值表示精度(范圍為-100到100),第二個數值表示緯度(范圍為-90到90)。

 

查詢結果
下圖的語句是查詢在經緯度為50和50位置附近的店鋪,但我們看到是報錯了,理由是我們要新建字段loc上面的地理索引。

 

  建立地理索引的步驟如下: (也就是在loc字段上面建立地理位置索引)

 

 我們重復執行剛才的語句,發現成功啦。

 

   現在我們寫一個稍微復雜的場景,我們要搜索在位置(50,50)附近的咖啡店,該排序是從近到遠排的。

 

  我們再寫一個更復雜的場景,我們要搜索在位置(50,50)附近的咖啡店,並且距離在37m之內。

 

還有一個參數是limit,控制店鋪數量的,如下:

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM