亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MongoDB中的定時索引示例詳解

 更新時間:2019年08月01日 15:28:47   作者:think123  
這篇文章主要給大家介紹了關于MongoDB中定時索引的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MongoDB具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

MongoDB中存在一種索引,叫做TTL索引(time-to-live index,具有生命周期的索引),這種索引允許為每一個文檔設置一個超時時間。一個文檔達到預設置的老化程度后就會被刪除。

數(shù)據(jù)到期對于某些類型的信息非常有用,例如機器生成的事件數(shù)據(jù),日志和會話信息,這些信息只需要在數(shù)據(jù)庫中保存有限的時間。

在createIndex中指定expireAfterSeconds選項就可以創(chuàng)建一個TTL索引:

// 超時時間為24小時,默認是前臺運行,可以通過background:true設置為后臺模式
db.user_session.createIndex({"updated":1},{expireAfterSeconds:60*60*24});

這樣在updated字段上創(chuàng)建了一個TTL索引。如果一個文檔的updated字段存在并且它的值是日期類型,當服務器時間比文檔的updated字段的時間晚expireAfterSeconds秒時,文檔就會被刪除。

db.getCollection('user_session').insert(
 {
  _id: NumberInt(1),
  "updated":new Date(),
   username:'lisi'
 }
);

mongodb保存時間使用的UTC時間,在查詢出來的結果的時候會轉換為GMT時間,所以你看到保存的時間和電腦時間相差8個小時(GMT+8)
db.getCollection('user_session').find({updated:{$gt: new Date("2019-07-12 14:00:00")}})  在查詢的時候可以使用new Date()直接進行時間的比較,new Date傳入的參數(shù)是GMT時間

為了防止活躍的會話被刪除,可以在會話上有活動發(fā)生時將updated字段的值更新為當前時間。只要updated的時間距離當前時間達到24小時。相應的文檔就會被刪除。

MongoDB的TTL功能依賴于mongodb中的后臺線程,該線程讀取索引中的日期類型值并從集合中刪除過期的文檔。

MongoDB每分鐘對TTL索引進行一次清理,所以不應該依賴以秒為單位的時間保證索引的存活狀態(tài)。而且TTL索引不保證在到期時立即刪除過期數(shù)據(jù)。文檔到期的時間與MongoDB從數(shù)據(jù)庫中刪除文檔的時間之間可能存在延遲。由于刪除過期文檔的后臺任務每60秒運行一次。所以,文檔可能在文檔到期和后臺任務運行之間的期間保留在集合中。

源碼在 github.com/mongodb/mon

mongodb不支持使用createIndex來重新設置過期時間,只可以使用collMod命令修改expireAfterSeconds的值:

db.runCommand({collMod:"user_session",index: {name:"updated_1",expireAfterSeconds: 120}});

修改成功后,你會收到這樣的消息(之前的過期時間是一分鐘,現(xiàn)在修改為2分鐘)

{
  "expireAfterSeconds_old" : 60.0,
  "expireAfterSeconds_new" : 120.0,
  "ok" : 1.0
}

在一個給定的集合上可以有多個TTL索引,你可以在created和updated字段分別建立ttl索引,但是不能同時使用兩個字段建立復合ttl索引,也不能在同一個字段上又是創(chuàng)建TTL索引,又是創(chuàng)建普通索引,但是可以像“普通索引”一樣用來優(yōu)化排序和查詢。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

  • mongo中模糊查詢的綜合應用

    mongo中模糊查詢的綜合應用

    這篇文章主要給大家介紹了關于mongo中模糊查詢的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mongodb具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • mongodb 數(shù)據(jù)生成Insert 語句的示例代碼

    mongodb 數(shù)據(jù)生成Insert 語句的示例代碼

    這篇文章主要介紹了mongodb 數(shù)據(jù)生成Insert 語句的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作,具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • MongoDB模糊查詢操作案例詳解(類關系型數(shù)據(jù)庫的 like 和 not like)

    MongoDB模糊查詢操作案例詳解(類關系型數(shù)據(jù)庫的 like 和 not like)

    這篇文章主要介紹了MongoDB的模糊查詢操作(類關系型數(shù)據(jù)庫的 like 和 not like) ,本文通過代碼案例分析給大家介紹的非常詳細,具有一定的參考借鑒價值,,需要的朋友可以參考下
    2019-07-07
  • 深入理解MongoDB的復合索引

    深入理解MongoDB的復合索引

    對于MongoDB的多鍵查詢,創(chuàng)建復合索引可以有效提高性能。這篇文章主要給大家介紹了關于MongoDB復合索引的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2018-03-03
  • mongodb中oplog介紹和格式詳析

    mongodb中oplog介紹和格式詳析

    Oplog 是用于存儲 MongoDB 數(shù)據(jù)庫所有數(shù)據(jù)的操作記錄的(實際只記錄增刪改和一些系統(tǒng)命令操作,查是不會記錄的),有點類似于 mysql 的 binlog 日志,這篇文章主要給大家介紹了關于mongodb中oplog和格式的相關資料,需要的朋友可以參考下
    2021-07-07
  • MongoDB數(shù)據(jù)庫常用28條查詢語句總結

    MongoDB數(shù)據(jù)庫常用28條查詢語句總結

    我們經(jīng)常使用的MySQL是最流行的關系型數(shù)據(jù)庫管理系統(tǒng),隨著時代的進步,互聯(lián)網(wǎng)的發(fā)展關系型數(shù)據(jù)庫已經(jīng)不滿足于互聯(lián)網(wǎng)的需求,因此出現(xiàn)了非關系數(shù)據(jù)庫,下面這篇文章主要給大家總結介紹了關于MongoDB數(shù)據(jù)庫常用28條查詢語句,需要的朋友可以參考下
    2023-05-05
  • MongoDB的啟動方法詳細總結

    MongoDB的啟動方法詳細總結

    MongoDB是一個基于分布式文件存儲的數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關于MongoDB啟動方法的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • Mongodb億級數(shù)據(jù)性能測試和壓測

    Mongodb億級數(shù)據(jù)性能測試和壓測

    MongoDB是一個開源的、基于分布式文件存儲的NoSQL數(shù)據(jù)庫系統(tǒng),它使用文檔存儲方式,數(shù)據(jù)結構由鍵值(key-value)對組成,本文給大家介紹了Mongodb億級數(shù)據(jù)性能測試和壓測,需要的朋友可以參考下
    2024-06-06
  • MongoDB修改數(shù)據(jù)的2種方法

    MongoDB修改數(shù)據(jù)的2種方法

    這篇文章主要介紹了MongoDB修改數(shù)據(jù)的2種方法,需要的朋友可以參考下
    2014-05-05
  • MongoDB單表數(shù)據(jù)的導出和恢復實例講解

    MongoDB單表數(shù)據(jù)的導出和恢復實例講解

    MongoDB 是一個跨平臺的,面向文檔的數(shù)據(jù)庫,提供高性能,高可用性和可擴展性方便。 MongoDB 工作在收集和文件的概念。接下來通過本文給大家介紹MongoDB單表數(shù)據(jù)的導出和恢復實例講解,對mongodb導出和恢復數(shù)據(jù)知識感興趣的朋友一起學習吧
    2016-03-03

最新評論