MongoDB之固定集合
所謂的固定集合是規定集合大小,如果要儲存的內容超過了集合的長度,那麼會採用LRU的演算法(最近最少使用原則)將最早的資料移出,從而儲存新的資料。
預設情況下一個集合可以使用createCollection()函式建立,或者使用增加資料後自動建立,但是如果要想使用固定集合,就必須明確建立一個空集合。
範例:建立一個空集合(固定集合)
> db.createCollection("dept",{"capped":true,"size":1024,"max":5});
{ "ok" : 1 }
其中"capped":true表示為一個固定集合,而"size":1024指的是集合所佔的空間容量(位元組),"max":5表示最多隻能夠有5條記錄。
範例:向集合裡面儲存5條資料
db.dept.insert({"deptno":10,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":11,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":12,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":13,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":14,"dname":"財務部","loc":"北京"});
> db.dept.find();
{ "_id" : ObjectId("599504e70184ff511bf02be0"), "deptno" : 10, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be1"), "deptno" : 11, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be2"), "deptno" : 12, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be3"), "deptno" : 13, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e80184ff511bf02be4"), "deptno" : 14, "dname" : "財務部", "loc" : "北京" }
此時已經達到了集合的上限,那麼繼續儲存新的內容:
> db.dept.insert({"deptno":16,"dname":"財務部","loc":"北京"});
WriteResult({ "nInserted" : 1 })
> db.dept.find();
{ "_id" : ObjectId("599504e70184ff511bf02be1"), "deptno" : 11, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be2"), "deptno" : 12, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be3"), "deptno" : 13, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e80184ff511bf02be4"), "deptno" : 14, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599505240184ff511bf02be5"), "deptno" : 16, "dname" : "財務部", "loc" : "北京" }
此時最早保留的資料已經消失了,實際上這種操作與快取機制是非常相似的。
預設情況下一個集合可以使用createCollection()函式建立,或者使用增加資料後自動建立,但是如果要想使用固定集合,就必須明確建立一個空集合。
範例:建立一個空集合(固定集合)
> db.createCollection("dept",{"capped":true,"size":1024,"max":5});
{ "ok" : 1 }
其中"capped":true表示為一個固定集合,而"size":1024指的是集合所佔的空間容量(位元組),"max":5表示最多隻能夠有5條記錄。
範例:向集合裡面儲存5條資料
db.dept.insert({"deptno":10,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":11,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":12,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":13,"dname":"財務部","loc":"北京"});
db.dept.insert({"deptno":14,"dname":"財務部","loc":"北京"});
> db.dept.find();
{ "_id" : ObjectId("599504e70184ff511bf02be0"), "deptno" : 10, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be1"), "deptno" : 11, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be2"), "deptno" : 12, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be3"), "deptno" : 13, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e80184ff511bf02be4"), "deptno" : 14, "dname" : "財務部", "loc" : "北京" }
此時已經達到了集合的上限,那麼繼續儲存新的內容:
> db.dept.insert({"deptno":16,"dname":"財務部","loc":"北京"});
WriteResult({ "nInserted" : 1 })
> db.dept.find();
{ "_id" : ObjectId("599504e70184ff511bf02be1"), "deptno" : 11, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be2"), "deptno" : 12, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e70184ff511bf02be3"), "deptno" : 13, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599504e80184ff511bf02be4"), "deptno" : 14, "dname" : "財務部", "loc" : "北京" }
{ "_id" : ObjectId("599505240184ff511bf02be5"), "deptno" : 16, "dname" : "財務部", "loc" : "北京" }
此時最早保留的資料已經消失了,實際上這種操作與快取機制是非常相似的。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28536251/viewspace-2144107/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 用mongodb 固定集合實現只保留固定數量的記錄,自動淘汰老舊資料MongoDB
- MongoDB之資料查詢(巢狀集合)MongoDB巢狀
- mongodb 分片叢集建立分片集合MongoDB
- MongoDB關聯另一個集合MongoDB
- MongoDB小技巧之如何使用帶下劃線的集合名查詢MongoDB
- MongoDB 集合的插入、更新、刪除操作MongoDB
- MongoDB建立大量集合測試問題MongoDB
- 技術乾貨| MongoDB時間序列集合MongoDB
- oracle之 AWR固定基線Oracle
- MongoDB叢集設定集合分片生效及檢視集合分片情況MongoDB
- MongoDB之聚合MongoDB
- MongoDB從入門到實戰之.NET Core使用MongoDB開發ToDoList系統(3)-系統資料集合設計MongoDB
- MongoDB mongoshake 遷移分片到複製集合MongoDB
- MongoDB中local.replset.minvalid集合的作用MongoDB
- Java 集合之ArrayListJava
- Java集合之HashMapJavaHashMap
- Java集合之ArrayListJava
- java集合之CopyOnWriteArrayListJava
- Java之Properties集合Java
- mongodb之shard分片MongoDB
- MongoDB之副本集MongoDB
- MongoDB之監控MongoDB
- MongoDB之GridFSMongoDB
- MongoDB之遊標MongoDB
- MongoDB之基本操作MongoDB
- Swift之集合型別 (Collection Types)(集合篇)Swift型別
- 小丸子學MongoDB系列之——安裝MongoDBMongoDB
- thinkphp5.x之Collection(集合)解析php集合PHP
- Java 集合之LinkedListJava
- Java集合之LinkedHashMapJavaHashMap
- Java集合系列之---HashMapJavaHashMap
- google guava集合之MultisetGoGuava
- Java集合系列之HashMapJavaHashMap
- 小丸子學MongoDB系列之——部署MongoDB副本集MongoDB
- MongoDB之索引(簡介)MongoDB索引
- MongoDB在不同主機間複製資料庫和集合MongoDB資料庫
- MongoDB如何查oplog.rs集合裡的操作日誌MongoDB
- Java高階特性之集合Java