一、前言
MongoDB 里面的日期類型是沒有時區概念的,默認存儲的是 ISODate("2018-04-02T13:19:16.418Z") 這種格式的零時區時間,比北京時間晚了八個小時。
工作中遇到了一個問題,怎么查詢比當前時間小30秒之內的文檔記錄呢?
時區問題有關系嗎?日期類型要怎么比較?怎么表示當前時間呢?日期要怎么實現加減呢?
二、方案
1、時區問題
其實時區問題並不是一個太需要關注的問題,因為MongoDB 提供了一個Javascript shell 窗口,支持 js 的語法。進行日期類型比較的時候,MongoDB 會自動處理 js 日期類型 和 MongoDB 日期類型間的時區問題。
2、怎么表示當前時間
既然我們已經有了 Javascript shell 窗口,那么表示當前時間不是一件輕而易舉的事情了嗎?直接一個 new Date() 就搞定了!
3、實現日期加減
有了 js 語法,日期的加減也不是特別難想了吧?
var now = new Date(); now.setTime(now.setSeconds(now.getMinutes() - 30));
4、實現查詢
萬事俱備,只欠東風。讓我們來看看,最后的MongoDB查詢是怎么樣的吧?
var now = new Date(); now.setTime(now.setSeconds(now.getMinutes() - 30)); db.driverLocation.find({"uploadTime":{"$gte":now}}).sort({"uploadTime":-1});