上QQ阅读APP看书,第一时间看更新
1.3 功能丰富
MongoDB 是通用型数据库,除了创建、读取、更新和删除数据外,它还提供了数据库管理系统的常见功能和许多其他独特的功能,举例如下。
索引
MongoDB 支持通用的二级索引,并提供唯一索引、复合索引、地理空间索引及全文索引功能。此外,它还支持在不同层次结构(如嵌套文档和数组)上建立二级索引,让开发人员能够以最适合应用程序的方式充分利用其建模能力。
聚合
MongoDB 提供了一种基于数据处理管道的聚合框架。用户可以通过在服务器端使用一系列相对简单的处理阶段,来充分利用数据库优化以构建复杂的分析引擎。
特殊的集合和索引类型
MongoDB 支持生命周期有限(TTL)集合,适用于保存将在特定时间过期的数据,比如会话和固定大小的集合,以及用于保存最近的数据(日志)。MongoDB 还支持部分索引,可以仅对符合某个条件的文档创建索引,以提高效率并减少所需的存储空间。
文件存储
针对大文件及文件元数据的存储,MongoDB 使用了一种非常易用的协议。
MongoDB 并不具备关系数据库中的一些常见功能,特别是复杂的连接操作。MongoDB 通过使用 3.2 版本引入的 $lookup 聚合运算符以非常有限的方式支持连接操作。在 3.6 版本中,可以使用多个连接条件以及非关联子查询来实现更复杂的连接。MongoDB 的这种处理是出于架构上的考虑,以便获得更好的可扩展性,因为这些特性在分布式系统中很难高效地实现。