【MongoDB学习笔记26】MongoDB的固定集合
admin
2023-04-12 09:43:35
0

MongoDB中的普通集合是动态的,可以自动增长容纳更多的数据;相对而言,有另一种集合称之为固定集合。

(1)固定集合需要实现显式创建,集合大小固定;

(2)一旦固定集合中空间用完,插入的新文档将覆盖最老的那个文档的空间,类似循环队列;

(3)固定集合不能被分片;

(4)固定集合不能修改,只能删除重建

 

一、创建固定集合

使用CreateCollection创建固定集合myCollection,字节大小限制在10000,文档数量限制在100:

> db.createCollection("myCollection",{capped:true,size:10000,max:100})   
{ "ok" : 1 }    
>

   

capped":是否固定集合;

"size":指定固定集合的字节大小;

"max":指定固定集合中的文档限制;

不管是先到”size“的限制还是”max“的限制,新文档都会覆盖最旧的文档;

 

二、将普通集合转化为固定集合

使用convertToCapped将已有的集合转化为固定集合:

> db.runCommand({convertToCapped:"foo","size":10000})   
{ "ok" : 1 }    
>

 

三、固定集合的自然排序

固定集合有特殊额排序,称为自然排序,它返回结果集中文档的顺序就是文档在磁盘上的顺序。

默认文档从旧到新的排序,也可以指定文档从新到旧的排序:

> db.foo.find().sort({$natural:-1})   
{ "_id" : 3, "x" : 3 }    
{ "_id" : 2, "x" : 2 }    
{ "_id" : 1, "x" : 1 }    
{ "_id" : 0 }    
>


四、没有_id索引的集合

默认情况下:

(1)普通集合都有一个“_id”索引。在显式创建集合的时候指定autoIndexId为false,将不会自动在_id字段上创建索引;

(2)固定集合没有_id字段的索引,除非在创建时候显式指定autoIndexId为true,或者事后用ensureIndex手动创建;

(3)_id字段上的索引必须是唯一索引;

 


五、循环游标

循环游标只能在固定集合中的一种特殊游标;

(1)当游标中的结果集被取光后,游标并不会关闭,而是等待有新文档插入集合后放入游标;

(2)循环游标超时10分钟后也会自动关闭,想使用循环游标也需要在游标释放后自动执行查询;

(3)不能在MongoDB shell中使用循环游标;



相关内容

热门资讯

热搜爆了!腾讯张军: 不会开发... 5月11日晚,“微信状态 访客记录”爆上热搜第一。 今天(5月12日),微信员工@客村小蒋发文回应:...
“人工胚胎”,首次进入太空! 来源:市场资讯 (来源:环球网资讯) 来源:央视新闻微信公众号 11日,我国天舟十号成功发射。“人工...
巨婴孙杨,屡教不改 内娱,终于等来了自己的综艺鬼才。体育冠军孙杨,人送外号“高需求宝宝”;艺术体操运动员张豆豆,被网友戏...
微纳米七级分散乳化机选型指南:... 导语:在医药制剂、化工新材料、食品加工等行业中,微纳米级分散乳化机的性能直接影响产品稳定性与生产效率...
全国率先!湖北人形机器人开始登... 当前,我国人形机器人产业爆发,各品牌机器人层出不穷。然而,不同品牌机器人由于技术路径不同,采用的零部...
国标出台,人工智能终端分级工作... 人工智能终端是人工智能技术规模化落地、体系化发展的关键载体。近年来,我国人工智能产业蓬勃发展,人工智...
OPPO「母亲节」交学费,另一... 「核心提示」 母亲节文案翻车背后:OPPO的营销,为何总在“雷区”蹦迪? 作者 | 李白 编...
今天,这场内阁会议或将决定斯塔... 英国工党日前在地方选举中大败,首相斯塔默地位岌岌可危,党内逼宫浪潮高涨。斯塔默将于5月12日召开一场...
定做衣柜要多少钱索菲亚定做衣柜... 回答1: 定做衣柜都是按平米计算的 索菲亚衣柜在全国有连锁店,价格也是统一的,一般一线城市跟...