返回顶部
首页 > 资讯 > 数据库 >【MongoDB学习笔记26】MongoDB的固定集合
  • 330
分享到

【MongoDB学习笔记26】MongoDB的固定集合

2024-04-02 19:04:59 330人浏览 泡泡鱼
摘要

mongoDB中的普通集合是动态的,可以自动增长容纳更多的数据;相对而言,有另一种集合称之为固定集合。(1)固定集合需要实现显式创建,集合大小固定;(2)一旦固定集合中空间用完,插入的新文档将覆盖最老的那个

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中使用循环游标;



您可能感兴趣的文档:

--结束END--

本文标题: 【MongoDB学习笔记26】MongoDB的固定集合

本文链接: https://lsjlt.com/news/36113.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 【MongoDB学习笔记26】MongoDB的固定集合
    MongoDB中的普通集合是动态的,可以自动增长容纳更多的数据;相对而言,有另一种集合称之为固定集合。(1)固定集合需要实现显式创建,集合大小固定;(2)一旦固定集合中空间用完,插入的新文档将覆盖最老的那个...
    99+
    2024-04-02
  • MongoDB笔记十二——固定集合
    1、固定集合的特性...
    99+
    2024-04-02
  • MongoDB学习笔记:副本集
    本文更新于2022-01-08,使用MongoDB 4.4.5。 目录单台服务器下创建副本集多台服务器下创建副本集重新启动并连接到副本集维护副本集节点 单台服务器下创建副本集 确保/data/db目录存在且当前系统用户有读写权限。例如...
    99+
    2019-12-08
    MongoDB学习笔记:副本集
  • MongoDB固定集合
    固定集合MongoDB 固定集合(Capped Collections)是性能出色且有着固定大小的集合,对于大小固定,我们可以想象其就像一个环形队列,当集合空间用完后,再插入的元素就会覆盖最初始的头部的元素...
    99+
    2024-04-02
  • 【MongoDB学习笔记21】MongoDB的复合索引
    索引的值是按照一定顺序排列的,因此使用索引键对文档进行搜索排序比较快;但是只有首先使用索引进行排序时,索引才有用;例如下面的排序里,“username”上的索引就没有起作用:> db.use...
    99+
    2024-04-02
  • 【MongoDB学习笔记30】MongoDB的聚合框架
    使用聚合框架可以对集合中的文档进行变换和组合。用多个构件创建一个管道(pipeline),用于对一连串的文档进行处理。这些构件包括:筛选(filtering)投射(projecting)分组(groupin...
    99+
    2024-04-02
  • 【MongoDB】Capped固定集合
        不同于普通集合,固定集合必须在使用之前显示创建,可以使用create命令创建固定集合。在shell中,可以使用db.createCollection函数://...
    99+
    2024-04-02
  • MongoDB学习笔记:默认数据库与集合
    本文更新于2022-01-15,使用MongoDB 4.4.5。 目录adminsystem.usersconfigchangelogchunkscollectionsdatabaseslockssettingsshardstagsloc...
    99+
    2018-04-08
    MongoDB学习笔记:默认数据库与集合
  • 【MongoDB学习笔记20】MongoDB的索引
    MongoDB的索引和关系型数据库的索引概念和功能是相同的:(1)不使用索引的搜索可以称为全表扫面,也就是说,服务器必须找完整个表才能查询整个结果;(2)建立索引后搜索,查询在索引中搜索,在索引的条目中找到...
    99+
    2024-04-02
  • 【MongoDB学习笔记34】MongoDB副本集设计原则
    MongoDB中副本集中有个重要的概念:大多数因为副本集只有一个节点为可读写,其他节点只可读;而主节点的选择由大多数决定的,只有在得到支持时才能继续作为主节点。(1)大多数这个数字的确认公式:M=int((...
    99+
    2024-04-02
  • 【MongoDB学习笔记32】MongoDB修改副本集配置
    一、删除副本集成员spock:PRIMARY> rs.config()    {       &nb...
    99+
    2024-04-02
  • 【MongoDB学习笔记27】MongoDB的TTL索引
    TTL索引(time-to-live index)允许为每一个文档设置一个超时时间,文档超过这个时间就会被删除。在ensureIndex中指定expireAfterSecs选项就可以创建一个TTL索引:&g...
    99+
    2024-04-02
  • MongoDB学习笔记:概述
    本文更新于2022-01-23,使用MongoDB 4.4.5。 目录与关系数据库比较组成数据库集合文档数据类型填充因子写入安全自然排序固定集合循环游标索引典型场景GridFS聚合MapReduce副本集同步心跳驱动程序分片连接身份验证系...
    99+
    2016-10-31
    MongoDB学习笔记:概述
  • MongoDB学习笔记:分片
    本文更新于2022-01-08,使用MongoDB 4.4.5。 目录单台服务器下创建分片多台服务器下创建分片重新启动并连接到分片 单台服务器下创建分片 确保/data/db目录存在且当前系统用户有读写权限。例如(需根据实际情况设置权...
    99+
    2021-03-30
    MongoDB学习笔记:分片
  • MongoDB学习笔记:JavaScript shell
    本文更新于2022-01-22,使用MongoDB 4.4.5。 目录辅助扩展edithelpitshow collectionsshow databasesshow dbsshow tablesshow usersuseBulkWrit...
    99+
    2021-02-08
    MongoDB学习笔记:JavaScript shell
  • MongoDB学习笔记:总览
    【MongoDB学习笔记1】基于CentOS 6.5安装MongoDBhttp://281816327.blog.51cto.com/907015/1598270 【MongoDB学习笔记2】Mo...
    99+
    2024-04-02
  • 【MongoDB学习笔记33】MongoDB副本集rs辅助函数
    rs是一个全局的变量,其中那个包含与复制相关的辅助函数,这些函数大多只是数据库命令的包装器,例如>db.adminCommand({“replSetInitiate”:config})就和>rs...
    99+
    2024-04-02
  • MongoDB中怎么固定集合
    MongoDB中怎么固定集合,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 所谓的固定集合是规定集...
    99+
    2024-04-02
  • 【MongoDB学习笔记22】MongoDB的索引管理
    使用ensureIndex函数创建集合的索引。对集合而言,每个索引只需要创建一次,重复创建没有任何作用;> show collections    s...
    99+
    2024-04-02
  • 【MongoDB学习笔记25】MongoDB的索引类型
    创建索引可以指定一些选项,使用不同的选项建立的索引会有不同的行为。 一、唯一索引唯一索引可以确保每一个文档的指定键都有唯一的值。例如,想确定文档中的username键不重复,创建一个唯一索引:&g...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作