分区索引
概念
每一个分区集合都会默认创建一个名叫“$shard”的索引,该索引叫做分区索引。
非分区集合不存在分区索引。
分区索引存在于分区集合所在的每一个分区组中,其字段定义顺序和排列与分区键相同。
Note:
任何用户定义的唯一索引必须包含分区索引中所有的字段,其字段顺序无关。
在分区集合中,_id 字段仅保证分区内该字段唯一,无法保证全局唯一。
示例
一个典型的分区索引如下:
- > db.foo.bar.listIndexes()
- {
- "IndexDef":
- {
- "name": "$shard",
- "_id": { "$oid": "515954bfa88873112fa6bd3a" },
- "key": { "Field1": 1, "Field2": -1 },
- "v": 0,
- "unique": false,
- "dropDups": false,
- "enforced": false
- },
- "IndexFlag": "Normal"
- }