mongodb插入的最後一個文檔

來源:互聯網
上載者:User
我們在使用Mongodb時,有一個需求,就是要 取得某個集合的最後一條記錄.
最開始的開始我們想通過 _id排序, 但是這個應該不是嚴格的順序.
我們還嘗試了時間戳記的方式,這個也不能解決我們的問題.
最後沒辦法我們就藉助,redis產生了自增的id,存入的mongodb中.
不過這個用法真的很噁心.大家有什麼好的方法解決這個問題嗎?

回複內容:

我們在使用Mongodb時,有一個需求,就是要取得某個集合的最後一條記錄.
最開始的開始我們想通過_id排序, 但是這個應該不是嚴格的順序.
我們還嘗試了時間戳記的方式,這個也不能解決我們的問題.
最後沒辦法我們就藉助,redis產生了自增的id,存入的mongodb中.
不過這個用法真的很噁心.大家有什麼好的方法解決這個問題嗎?

_id排就可以了,這個得產生本身就跟時間有關係

ObjectId is a 12-byte BSON type, constructed using:

a 4-byte value representing the seconds since the Unix epoch,
a 3-byte machine identifier,
a 2-byte process id, and
a 3-byte counter, starting with a random value

如果沒有自己複寫_id的演算法,可以用_id直接排序的

除非你們自己生產了Mongodb的ObjectId,否則_id是絕對唯一的primary key. 通過下面的排序就可以輕易得到最後一條資料.

 $sort:{_id:-1 }
  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.