MongoDB日期查詢操作圖文詳解
MongoDB日期查詢詳解(數據庫默認是UTC標準時間)
一、MongoDB日期查詢格式
MongoDB中日期查詢格式采用ISODate()函數加上日期字符串的形式,如下所示:
db.collection.find({create_time:{$gte:ISODate("2021-01-01T00:00:00.000Z")}})
其中,'gte’表示大于等于,'lte’表示小于等于,'gt’表示大于,'lt’表示小于,'ISODate()'包含了日期數據的時間戳,需要放置在雙引號中。
二、MongoDB查詢日期類型數據
在MongoDB中,日期類型數據存儲方式為ISODate格式,可以通過以下方式進行數據插入:
db.collection.insert({
create_time: new Date()
})
通過new Date()生成當前時間并且存入create_time字段中,查詢數據時可以根據需要進行日期查詢。
三、MongoDB查詢語句
MongoDB查詢語句使用find()函數進行操作,可以根據需要進行條件查詢。
db.collection.find({create_time: {$gte: ISODate("2020-01-01T00:00:00.000Z")}})
在上面的例子中,查詢了所有create_time字段大于等于"2020-01-01T00:00:00.000Z"的數據。
四、MongoDB中日期類型
MongoDB中日期類型包括ISODate和Timestamp兩種類型,其中ISODate類型的日期精確到毫秒,可以進行具體的時間計算和比較;而Timestamp類型只精確到秒級別,只能做到粗略的時間計算和比較。
五、MongoDB查詢過程圖
查詢過程圖如下:
collection.find(query).skip(offset).limit(limit)
|
v
query = {'create_time': {'$gte': ISODate('2021-01-01T00:00:00.000Z')}}
|
v
MongoDB查詢數據過程,取出滿足條件的數據
|
v
對數據進行分頁處理,返回需要的數據
六、MongoDB時間查詢
針對特定日期進行查詢,可以使用以下方法:
db.collection.find({
create_time: {$gte: ISODate("2021-01-01T00:00:00.000Z"), $lte: ISODate("2021-01-31T23:59:59.999Z")}
})
在上面的例子中,查詢了所有create_time字段在"2021-01-01T00:00:00.000Z"和"2021-01-31T23:59:59.999Z"之間的數據。
七、MongoDB查詢效率
MongoDB查詢效率受到多個因素的影響,包括數據量、查詢條件、索引設置等等。
最佳實踐包括:
- 設置合適的索引
- 避免使用全文索引
- 使用projection來限制查詢返回的字段
- 使用游標來批量獲取數據
八、MongoDB count查詢
MongoDB count查詢可以使用countDocuments()函數和estimatedDocumentCount()函數進行操作,其中countDocuments()對大型數據集有更好的性能表現,而estimatedDocumentCount()則可以獲取更快的響應時間。
db.collection.countDocuments({create_time:{$gte:ISODate("2021-01-01T00:00:00.000Z")}})
db.collection.estimatedDocumentCount()
九、補充
- 數據庫配置的是UTC標準時間,查詢東八區(qū)日期時得減8小時
例如查找東八區(qū)創(chuàng)建日期大于2023-12-06T11:00:00.000,相當于UTC查找創(chuàng)建日期大于2023-12-06T03:00:00.000Z
db.collection.find({create_time:{$gte:ISODate("2023-12-06T03:00:00.000Z")}})

我們也可以使用東八區(qū)的格式來查,只不過不需要減8小時,雖然配置的是UTC但是會自動將東八區(qū)轉為UTC時間來查。
db.book.find({updateTime:{$gte:ISODate("2023-12-06T11:00:00.000+08:00")}})

- 數據庫配置的是LocalTinezone,查詢東八區(qū)日期時正常查詢不需要減
db.book.find({updateTime:{$gte:ISODate("2023-12-06T11:00:00.000+08:00")}})

我們也可以使用UTC的格式來查,只不過需要減8小時,雖然配置的是東八區(qū)但是會自動將UTC轉為東八區(qū)時間來查。
db.collection.find({create_time:{$gte:ISODate("2023-12-06T03:00:00.000Z")}})

結論:
無論數據庫的配置是UTC還是LocalTinezone,使用何種語句本質相同就是代表查詢的是東八區(qū)時間。
db.collection.find({create_time:{$gte:ISODate("2023-12-06T03:00:00.000Z")}})
db.book.find({updateTime:{$gte:ISODate("2023-12-06T11:00:00.000+08:00")}})總結
到此這篇關于MongoDB日期查詢操作的文章就介紹到這了,更多相關MongoDB日期查詢內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySQL密碼策略管理插件validate_password用法詳解
自MySQL5.6起,引入validate_password插件,用于密碼長度和強度管理,在MySQL8.0中,該插件通過服務器組件重新實現,插件默認不允許密碼為用戶名,可設定最小長度和強度等級,還可要求密碼包含數字、大小寫字母和特殊字符2024-11-11

