天天看點

MongoDB的地理位置索引背景如何使用

MongoDB的地理位置索引背景如何使用

背景

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

MongoDB的地理位置索引背景如何使用

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

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

如何使用

前期準備:插入資料

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

MongoDB的地理位置索引背景如何使用

查詢結果

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

MongoDB的地理位置索引背景如何使用

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

MongoDB的地理位置索引背景如何使用

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

MongoDB的地理位置索引背景如何使用

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

MongoDB的地理位置索引背景如何使用

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

MongoDB的地理位置索引背景如何使用

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

MongoDB的地理位置索引背景如何使用
MongoDB的地理位置索引背景如何使用