MongoDB之固定集合

stonebox1122發表於2017-08-24
所謂的固定集合是規定集合大小,如果要儲存的內容超過了集合的長度,那麼會採用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" : "北京" }

此時最早保留的資料已經消失了,實際上這種操作與快取機制是非常相似的。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28536251/viewspace-2144107/,如需轉載,請註明出處,否則將追究法律責任。

相關文章