1.定义
固定集合大小固定,必须事先创建,并且指定大小。
固定集合很像环形队列,如果空间不足,最早的文档就会被删除,为新的文档腾出空间,即自动淘汰最早的文档。
2.与普通集合的区别
1)不能删除文档
2)更新不能导致文档移动,即更新不能使得被更新的文档的存储空间变大
3)在默认情况下固定集合没有索引
3.特点
1)插入速度极快
2)按照插入顺序输出的查询速度极快
4.应用
1)日志
2)缓存少量的文档
3)任何想要自动淘汰过期属性的场景
5.创建
方法一: db.createCollection("sys_log", {"capped": true, size: 100, max: 20}); sys_log: 集合名 capped: true,表示为固定集合 size: 集合字节大小 max: 文档数量的上限 方法二: db.runCommand({"convertToCapped": "user", "size": 100}); convertToCapped: 要转化为固定集合的普通集合名 size: 集合字节大小
6.自然排序
自然顺序就是文档在磁盘上的顺序,即文档的插入顺序,自然排序就是与此相同的。
默认情况下,查询固定集合后就是按照插入顺序返回文档。即:
db.sys_log.find().sort({"$natural": 1});
也可以使用自然排序按照反向插入的顺序查询:
db.sys_log.find().sort({"$natural": -1});
注:非固定集合不能保证文档按照特定顺序存储,所以自然顺序的意义不大。
相关推荐
MongoDB的固定集合(Capped Collections)是一种特殊类型的集合,设计用于高效地存储有固定大小限制的数据,类似于一个循环缓冲区。固定集合的主要特点是它的大小是固定的,一旦达到上限,新的插入操作会覆盖最早的...
在MongoDB中,固定集合(capped collection)是一种特殊类型的集合,具有固定大小和自动溢出处理机制。当固定集合达到其容量时,新插入的文档会替换最旧的文档,确保集合始终保持在设定的大小内。 1. 创建固定集合...
MongoDB中有一种特殊类型的集合,值得我们特别留意,那就是固定集合(capped collection)。 固定集合可以声明collection的容量大小,其行为类似于循环队列。数据插入时,新文档会被插入到队列的末尾,如果队列已经...
集合可以通过 `db.createCollection(name, options)` 创建,其中`options`可以包含`size`(预分配空间)、`capped`(是否为固定大小的集合)和`max`(固定集合的最大文档数)等。 4. **删除集合**: `db.mycoll....
这段代码会创建一个上限为1MB且最多存储10000个文档的固定大小(capped)集合。 6. 关闭连接 当完成数据库操作后,别忘了关闭连接: ```java mongoClient.close(); ``` 7. 错误处理 在示例代码中,我们使用了异常...
例如,创建一个名为 `myCollection` 的固定集合,大小为 1024000 KB,最多允许 10000 个文档: ```javascript > use test switched to db test > db.createCollection("myCollection", {capped : true, autoIndexId...
MongoDB 还提供了一种特殊的集合类型——“固定大小集合”(Capped Collections),用于实现高性能的队列功能。Capped Collections 有固定的存储容量,一旦达到上限,新插入的数据会替换最旧的数据,保持集合的大小...
2. **集合**:MongoDB 中的文档被组织在集合(Collections)中,类似于关系数据库中的表,但它们不需要有一个固定的模式。 3. **高性能**:MongoDB 提供高性能的数据持久化,特别是在处理大量的读写操作时。 4. **...
固定集合是MongoDB中一个特殊的数据结构,用于满足某些特殊场景下的性能和存储需求。固定集合有着固定的大小限制,并且按照先进先出的顺序来添加和移除数据项。这种方式适合于记录日志、消息队列等场景。 MongoDB...
视频目录: 01-mongodb文档型...07-固定集合 07-索引 08-备份与恢复 08-用户管理 09-mongoDB备份与恢复 09-安全和认证 10-replication复制集 10-主从复制 11-shard分片 11-分片 12-使用java操作mongodb
MongoDB 不同于传统的关系型数据库,它采用面向集合的存储方式,支持无模式的数据模型,允许数据自由组织,这使得它特别适合处理大规模、结构不固定的数据。 在MongoDB中,数据是以文档的形式存储在集合中,文档是...
相比于传统的行式数据库,MongoDB更加适合处理结构不固定或半结构化的数据。 在Linux环境下安装MongoDB 4.0.0,首先要确保系统满足其依赖条件,通常包括GCC编译器、curl库和其它必要的开发工具。接下来,可以通过...
MongoDB采用NoSQL数据模型,它不同于传统的关系型数据库,如MySQL或Oracle,后者依赖于固定的表结构和行列式数据存储。MongoDB使用文档(BSON格式,一种JSON的扩展)作为数据存储单元,这些文档可以包含嵌套的数据...
2. **集合(Collection)**:集合相当于关系型数据库中的表,但没有固定的模式。集合包含一个或多个文档,文档之间不必有相同的字段或结构。 3. **数据库(Database)**:数据库是MongoDB中存储数据的基本单位,...
总结来说,MongoDB是一款灵活、高性能的NoSQL数据库,尤其适合处理结构不固定或半结构化的数据。在Linux上部署MongoDB涉及下载安装、配置环境变量、创建数据目录以及启动服务等步骤。Mongo Shell提供了一个便捷的...
MongoDB使用的是集合(Collection)作为存储数据的容器,每个集合可以包含多个JSON格式的文档(Document)。它支持嵌套文档(Embedded Document)和分片(Shard),使用分片键(ShardKey)来分布数据。 9. MongoDB...
NoSQL系统通常不要求固定的表结构,通常具有高度的伸缩性和可用性。 - **MongoDB**:MongoDB是一款开源的、基于分布式文件存储的NoSQL数据库。它使用JSON-BSON格式来存储文档,这种灵活的数据模型非常适合存储复杂...
2. 集合与文档:集合类似于关系数据库中的表,但没有固定的列结构。文档是集合中的基本单元,每个文档都是一组键值对。 3. 数据库:MongoDB中的数据库是一个命名的空间,用于存储集合。每个数据库都有一个唯一的...