1. 程式人生 > >MongoDB的地理位置索引

MongoDB的地理位置索引

背景

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

這種計算如果通過普通的關係型資料庫,那對伺服器和資料庫的效能要求就太高了。

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

如何使用

前期準備:插入資料

我們先插入四條資料,即店鋪的型別,名稱和地理位置。注意地理位置的第一個數值表示精度(範圍為-100到100),第二個數值表示緯度(範圍為-90到90)。

查詢結果

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

 

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

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

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

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

 

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