MongoDB:17-MongoDB-索引限制及其他限制规则

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: MongoDB:17-MongoDB-索引限制及其他限制规则


索引-额外开销


  1. 每个索引占据一定的存储空间,在进行插入,更新和删除操作时也需要对索引进行操作。
  2. 所以,如果你很少对集合进行读取操作,建议不使用索引。


索引-内存(RAM)使用


  1. 由于索引是存储在内存(RAM)中,你应该确保该索引的大小不超过内存的限制。
  2. 如果索引的大小大于内存的限制,MongoDB会删除一些索引,这将导致性能下降。


索引-查询限制


  1. 索引不能被以下的查询使用:
  • 正则表达式及非操作符,如 $nin, $not,等。
  • 算术运算符,如 $mod,等。
  • $where 子句
  1. 所以,检测你的语句是否使用索引是一个好的习惯,可以用explain来查看。


索引键限制


  1. 2.6版本开始,如果现有的索引字段的值超过索引键的限制,MongoDB中不会创建索引。


插入文档超过索引键限制


  1. 如果文档的索引字段值超过了索引键的限制,MongoDB不会将任何文档转换成索引的集合。
  2. 与mongorestore和mongoimport工具类似。


索引-最大范围限制


  1. 1、索引关键字:该字段的取值不能超过1024字节,否则不能添加到一个索引中。
  2. 2、集合的最大所有个数:64
  3. 3、索引名称长度:包括数据库于集合名称总共不超过125字符。
  4. 4、联合索引最大字段个数:31
  5. 5、不能联合使用text索引与其他类型索引


附录:


Mongo限制规则


  1. 一、BSON 文档
  2. 1BSON文档大小,最大限制为16MB,这种限制是为了确保单个文档不会使用过多的RAM,或者在迁移期间不会占用过多的带宽。为了保存大于该限制的文档,mongodb提供了GridFS
  3. 当插入的文档大于16MB时将得到如下的错误信息(java客户端):
  1. com.mongodb.MongoInternalException: DBObjectof size 30836631 is over MaxBSON size 16777216

  1. 2、文档的最大嵌套数为 100
  2. 二、名字空间
  3. 1、名字空间长度限制:包括数据库与集合名称,总共不能超过123字节
  4. 2、名字空间数量:
  1. mongo为每个数据库保存一个16MB的名字空间文件,dbname.ns ,每个名称占用628字节,
  2. 因此默认可以支持24000个名字空间(索引也占用一个名字空间)。
  1. 3、名字空间文件大小:最大不超过2048MB,默认为16MB,可以使用nssize选项进行配置。
  2. 三、索引
  3. 1、索引关键字:该字段的取值不能超过1024字节,否则不能添加到一个索引中。
  4. 2、集合的最大所有个数:64
  5. 3、索引名称长度:包括数据库于集合名称总共不超过125字符。
  6. 4、联合索引最大字段个数:31
  7. 5、不能联合使用text索引与其他类型索引
  8. 四、帽子集合(CappedCollections
  9. 1、帽子集合的最大文档数:当在创建时候执行最大文档数参数时,该值必须小于232次方。
  10.   若在创建的时候没有指定则文档数不限制。
  11. 五、复制集
  12. 1、最大的复制集个数:12
  13. 2、复制集的投票成员个数:任何时刻最大只有7个成员拥有投票权
  14. 六、分片集群
  15. 1、在分片环境中不支持的操作:group、eval、$where $isolated $snapshot geoSearch
  16. 2、已存在数据的分片:对于已存在数据的集合,分片的最大支持数据为256GB. 在集群环境之中最大支持的分片集合大约为400GB。精确的阈值根据chunk于数据大小而定。(也就是说,如果要对已有的集合进行分片,那么要在其增长到256G之前进行)。
  17. 3、分片集合中的文档更新:所有update、remove操作必须包括分片关键字或者id字段作为查询字段。若没有这些字段将失败。
  18. 4、分片集合中的唯一索引:除非唯一索引关键字使用shard key作为前缀,否则不支持。当使用shardkey作为前缀时,mongo将强制整个key唯一,而非单一字段。 具体可参考:http://docs.mongodb.org/manual/tutorial/enforce-unique-keys-for-sharded-collections/
  19. 七、分片关键字限制
  20. 1、关键字不能超过512字节。
  21. 2、关键字不允许变更:若要修改可采用如下方式:
  22. 1)导出所有数据到另外的格式
  23. 2)删除原来的分片集合
  24. 3)配置新的分片关键字
  25. 4)预先分割关键字范围确保实现分布式
  26. 5)保存导出的数据到mongo之中。
  27. 3、关键字值不允许修改:当一个文档已经插入到分片集合中后,涉及到分片关键字的字段不允许update。
  28. 4、单调递增/递减的分片关键字会限制插入效率:
  29. 如果使用_id字段作为分片关键字,由于该字段根据time递增,因此这也是一个会影响插入效率的。当向单调递增或递减的分片关键字集合中插入数据时,所有的插入将会导入到同一个chunk同一个分片之中。
  30. 加入在集群中以读取和更新占据主导,则这种限制并不影响集群。
  31. 为了避免这种限制,使用一个哈希分片关键字或者选择一个非单调递增递减的字段。
  32. 八、操作
  33. 1、联合多个$in操作:
  1. 联合多个in表达式,将可能触发联合索引的合并限制。
  2. 如果符合的item大于等于4000000,mongo将产生“combinatorial limit of $in partitioning of result set exceeded” 错误。

  1. 九、命名限制
  2. 1、数据库名称是大小写区别的:同时mongo也不允许两个数据库名称仅仅为大小写区别。
  3. 2、在windows下的数据库名称限制:/\. "*<>:|? 并且不能包括空格符。
  4. 3、在UnixLinux下的数据库名称限制:/\. " 同样不能包括空格符。
  5. 4、数据库名称长度:64字节
  6. 5、集合名称限制:
  7. 必须以下划线或者字母开头,并且不能包括 $,引号,空格符,点号
  8. 6、字段名称限制:
  9. 不能包括点号,$,与空格符。


相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
25天前
|
监控 NoSQL MongoDB
MongoDB数据库的索引管理技巧
【8月更文挑战第20天】MongoDB数据库的索引管理技巧
42 1
|
2月前
|
NoSQL Java API
MongoDB 强制使用索引 hint
MongoDB 强制使用索引 hint
75 3
|
3月前
|
存储 监控 NoSQL
MongoDB索引解析:工作原理、类型选择及优化策略
MongoDB索引解析:工作原理、类型选择及优化策略
|
3月前
|
NoSQL 定位技术 MongoDB
深入探索 MongoDB:高级索引解析与优化策略
深入探索 MongoDB:高级索引解析与优化策略
|
3月前
|
NoSQL 定位技术 MongoDB
解锁MongoDB索引的秘密:优化查询效率与应对限制的策略
解锁MongoDB索引的秘密:优化查询效率与应对限制的策略
|
1月前
|
存储 NoSQL 关系型数据库
4-MongoDB索引知识
MongoDB通过索引提升查询效率,避免全集合扫描。索引采用B树结构存储部分数据集,按字段值排序,支持快速匹配与排序查询。主要类型包括:单字段索引,支持升序/降序;复合索引,字段顺序影响排序逻辑;地理空间索引,适用于坐标数据查询;文本索引,用于搜索字符串内容;哈希索引,用于散列分片,仅支持等值查询。更多详情参见官方文档:[MongoDB索引指南](https://docs.mongodb.com/manual/indexes/)。
|
1月前
|
存储 NoSQL 安全
MongoDB:它如何悄然改变了全球开发者的数据游戏规则?
【8月更文挑战第8天】MongoDB是一款革命性的文档数据库,在开发者数据平台领域享有盛誉。以其独特的文档数据模型著称,无需预定义复杂模式即可高效存储与处理数据。支持实时数据分析及多云全球化部署,并具备企业级安全特性。从快速开发到大数据分析,MongoDB为现代应用提供全方位支持。
41 1
|
1月前
|
存储 NoSQL 物联网
MongoDB:改变游戏规则的数据库,看它如何统治数据世界的每一个角落
【8月更文挑战第7天】MongoDB是一款高性能、开源的NoSQL数据库,采用文档数据模型,支持丰富查询语言及二级索引。其灵活的数据模型和扩展性使其在大数据应用、实时分析、物联网、内容管理系统及电子商务平台等多种现代场景中广泛应用。例如,在大数据应用中,它可以高效存储社交媒体的非结构化数据;在实时分析中,能快速处理新数据并即时更新结果;在物联网应用中,则适用于存储大量非结构化传感器数据;而在内容管理和电子商务平台中,能提供灵活的内容存储和高效的商品搜索功能。
50 2
|
2月前
|
SQL NoSQL MongoDB
MongoDB 索引类型介绍
MongoDB 索引类型介绍
34 3
|
2月前
|
存储 NoSQL MongoDB
MongoDB 索引原理与索引优化
MongoDB 索引原理与索引优化
23 1