分区索引

概念

每一个分区集合都会默认创建一个名叫“$shard”的索引,该索引叫做分区索引。

非分区集合不存在分区索引。

分区索引存在于分区集合所在的每一个分区组中,其字段定义顺序和排列与分区键相同。

Note:

任何用户定义的唯一索引必须包含分区索引中所有的字段,其字段顺序无关。

在分区集合中,_id 字段仅保证分区内该字段唯一,无法保证全局唯一。

示例

一个典型的分区索引如下:

  1. > db.foo.bar.listIndexes()
  2. {
  3. "IndexDef":
  4. {
  5. "name": "$shard",
  6. "_id": { "$oid": "515954bfa88873112fa6bd3a" },
  7. "key": { "Field1": 1, "Field2": -1 },
  8. "v": 0,
  9. "unique": false,
  10. "dropDups": false,
  11. "enforced": false
  12. },
  13. "IndexFlag": "Normal"
  14. }