欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB日期查詢操作圖文詳解

 更新時(shí)間:2024年02月21日 08:52:51   作者:Major_xx  
MongoDB中按日期查詢是一種常見(jiàn)的查詢操作,而按日期查詢也是開(kāi)發(fā)人員在MongoDB工作中最常遇到的查詢?nèi)蝿?wù)之一,這篇文章主要給大家介紹了關(guān)于MongoDB日期查詢操作的相關(guān)資料,需要的朋友可以參考下

MongoDB日期查詢?cè)斀猓〝?shù)據(jù)庫(kù)默認(rèn)是UTC標(biāo)準(zhǔn)時(shí)間)

一、MongoDB日期查詢格式

MongoDB中日期查詢格式采用ISODate()函數(shù)加上日期字符串的形式,如下所示:

db.collection.find({create_time:{$gte:ISODate("2021-01-01T00:00:00.000Z")}})

其中,'gte’表示大于等于,'lte’表示小于等于,'gt’表示大于,'lt’表示小于,'ISODate()'包含了日期數(shù)據(jù)的時(shí)間戳,需要放置在雙引號(hào)中。

二、MongoDB查詢?nèi)掌陬?lèi)型數(shù)據(jù)

在MongoDB中,日期類(lèi)型數(shù)據(jù)存儲(chǔ)方式為ISODate格式,可以通過(guò)以下方式進(jìn)行數(shù)據(jù)插入:

db.collection.insert({
  create_time: new Date()
})

通過(guò)new Date()生成當(dāng)前時(shí)間并且存入create_time字段中,查詢數(shù)據(jù)時(shí)可以根據(jù)需要進(jìn)行日期查詢。

三、MongoDB查詢語(yǔ)句

MongoDB查詢語(yǔ)句使用find()函數(shù)進(jìn)行操作,可以根據(jù)需要進(jìn)行條件查詢。

db.collection.find({create_time: {$gte: ISODate("2020-01-01T00:00:00.000Z")}})

在上面的例子中,查詢了所有create_time字段大于等于"2020-01-01T00:00:00.000Z"的數(shù)據(jù)。

四、MongoDB中日期類(lèi)型

MongoDB中日期類(lèi)型包括ISODate和Timestamp兩種類(lèi)型,其中ISODate類(lèi)型的日期精確到毫秒,可以進(jìn)行具體的時(shí)間計(jì)算和比較;而Timestamp類(lèi)型只精確到秒級(jí)別,只能做到粗略的時(shí)間計(jì)算和比較。

五、MongoDB查詢過(guò)程圖

查詢過(guò)程圖如下:

  collection.find(query).skip(offset).limit(limit)
        |
        v
  query = {'create_time': {'$gte': ISODate('2021-01-01T00:00:00.000Z')}}
        |
        v
  MongoDB查詢數(shù)據(jù)過(guò)程,取出滿足條件的數(shù)據(jù)
        |
        v
  對(duì)數(shù)據(jù)進(jìn)行分頁(yè)處理,返回需要的數(shù)據(jù)

六、MongoDB時(shí)間查詢

針對(duì)特定日期進(jìn)行查詢,可以使用以下方法:

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"之間的數(shù)據(jù)。

七、MongoDB查詢效率

MongoDB查詢效率受到多個(gè)因素的影響,包括數(shù)據(jù)量、查詢條件、索引設(shè)置等等。

最佳實(shí)踐包括:

  • 設(shè)置合適的索引
  • 避免使用全文索引
  • 使用projection來(lái)限制查詢返回的字段
  • 使用游標(biāo)來(lái)批量獲取數(shù)據(jù)

八、MongoDB count查詢

MongoDB count查詢可以使用countDocuments()函數(shù)和estimatedDocumentCount()函數(shù)進(jìn)行操作,其中countDocuments()對(duì)大型數(shù)據(jù)集有更好的性能表現(xiàn),而estimatedDocumentCount()則可以獲取更快的響應(yīng)時(shí)間。

db.collection.countDocuments({create_time:{$gte:ISODate("2021-01-01T00:00:00.000Z")}})
db.collection.estimatedDocumentCount()

九、補(bǔ)充

  • 數(shù)據(jù)庫(kù)配置的是UTC標(biāo)準(zhǔn)時(shí)間,查詢東八區(qū)日期時(shí)得減8小時(shí)

例如查找東八區(qū)創(chuàng)建日期大于2023-12-06T11:00:00.000,相當(dāng)于UTC查找創(chuàng)建日期大于2023-12-06T03:00:00.000Z

db.collection.find({create_time:{$gte:ISODate("2023-12-06T03:00:00.000Z")}})

我們也可以使用東八區(qū)的格式來(lái)查,只不過(guò)不需要減8小時(shí),雖然配置的是UTC但是會(huì)自動(dòng)將東八區(qū)轉(zhuǎn)為UTC時(shí)間來(lái)查。

db.book.find({updateTime:{$gte:ISODate("2023-12-06T11:00:00.000+08:00")}})

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

我們也可以使用UTC的格式來(lái)查,只不過(guò)需要減8小時(shí),雖然配置的是東八區(qū)但是會(huì)自動(dòng)將UTC轉(zhuǎn)為東八區(qū)時(shí)間來(lái)查。

db.collection.find({create_time:{$gte:ISODate("2023-12-06T03:00:00.000Z")}})

結(jié)論:

無(wú)論數(shù)據(jù)庫(kù)的配置是UTC還是LocalTinezone,使用何種語(yǔ)句本質(zhì)相同就是代表查詢的是東八區(qū)時(shí)間。

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")}})

總結(jié) 

到此這篇關(guān)于MongoDB日期查詢操作的文章就介紹到這了,更多相關(guān)MongoDB日期查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL如何計(jì)算連續(xù)登錄天數(shù)

    MySQL如何計(jì)算連續(xù)登錄天數(shù)

    這篇文章主要介紹了MySQL如何計(jì)算連續(xù)登錄天數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • centos上安裝mysql并設(shè)置遠(yuǎn)程訪問(wèn)的操作方法

    centos上安裝mysql并設(shè)置遠(yuǎn)程訪問(wèn)的操作方法

    這篇文章主要介紹了centos上安裝mysql并設(shè)置遠(yuǎn)程訪問(wèn)的操作方法,需要的朋友可以參考下
    2017-11-11
  • Window Docker 安裝MySQL8.0的過(guò)程詳解

    Window Docker 安裝MySQL8.0的過(guò)程詳解

    本文給大家介紹在Windows環(huán)境下安裝Docker并配置MySQL容器的全流程介紹,過(guò)程中還涉及到文件映射和客戶端連接MySQL的操作,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • mysql?sql_mode數(shù)據(jù)驗(yàn)證檢查方法

    mysql?sql_mode數(shù)據(jù)驗(yàn)證檢查方法

    sql_mode?會(huì)影響MySQL支持的sql語(yǔ)法以及執(zhí)行的數(shù)據(jù)驗(yàn)證檢查,通過(guò)設(shè)置sql_mode?,可以完成不同嚴(yán)格程度的數(shù)據(jù)校驗(yàn),有效地保障數(shù)據(jù)準(zhǔn)確性,這篇文章主要介紹了mysql?sql_mode數(shù)據(jù)驗(yàn)證檢查,需要的朋友可以參考下
    2023-08-08
  • MySQL8.0創(chuàng)建用戶和權(quán)限控制示例詳解

    MySQL8.0創(chuàng)建用戶和權(quán)限控制示例詳解

    這篇文章主要為大家介紹了MySQL8.0創(chuàng)建用戶和權(quán)限控制實(shí)現(xiàn)過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • MySQL筆記之修改表的實(shí)現(xiàn)方法

    MySQL筆記之修改表的實(shí)現(xiàn)方法

    我們?cè)趧?chuàng)建表的過(guò)程中難免會(huì)考慮不周,因此后期會(huì)修改表。本篇文章就介紹了在mysql中修改表的實(shí)現(xiàn)方法。需要的朋友參考下
    2013-05-05
  • MySQL8.0就地升級(jí)到MySQL8.4.0的方法

    MySQL8.0就地升級(jí)到MySQL8.4.0的方法

    本文主要介紹了MySQL8.0就地升級(jí)到MySQL8.4.0的方法,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • MySQL表的重命名字段添加及字段屬性修改操作語(yǔ)法

    MySQL表的重命名字段添加及字段屬性修改操作語(yǔ)法

    這篇文章主要為大家介紹了MySQL表的重命名字段添加及字段屬性修改語(yǔ)法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • MySQL密碼策略管理插件validate_password用法詳解

    MySQL密碼策略管理插件validate_password用法詳解

    自MySQL5.6起,引入validate_password插件,用于密碼長(zhǎng)度和強(qiáng)度管理,在MySQL8.0中,該插件通過(guò)服務(wù)器組件重新實(shí)現(xiàn),插件默認(rèn)不允許密碼為用戶名,可設(shè)定最小長(zhǎng)度和強(qiáng)度等級(jí),還可要求密碼包含數(shù)字、大小寫(xiě)字母和特殊字符
    2024-11-11
  • MySQL語(yǔ)句整理及匯總介紹

    MySQL語(yǔ)句整理及匯總介紹

    今天小編就為大家分享一篇關(guān)于MySQL語(yǔ)句整理及匯總介紹,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01

最新評(píng)論