在MongoDB中对_id上的碎片密钥进行了哈希处理,然后呢?
如果我用在MongoDB中对_id上的碎片密钥进行了哈希处理,然后呢?,mongodb,sharding,Mongodb,Sharding,如果我用ensureIndex({u id:“hashed”})创建了一个散列索引,Mongo会知道在\u id字段上进行任何查询,并根据散列索引运行它们吗?或者我需要更新所有使用_id作为哈希索引的\u id\u的查询吗?创建哈希索引时,Mongodb不会修改\u id字段。它将做正确的事情,并适当地查询\u id。散列将仅用于查询和平衡碎片。当您创建id:“散列”索引时,它是常规的\u id:1索引之外的索引。是否有方法将现有的\u id:1索引替换为“\u id:“散列”?我已经创建了一个
ensureIndex({u id:“hashed”})
创建了一个散列索引,Mongo会知道在\u id
字段上进行任何查询,并根据散列索引运行它们吗?或者我需要更新所有使用_id作为哈希索引的\u id\u的查询吗?创建哈希索引时,Mongodb不会修改\u id
字段。它将做正确的事情,并适当地查询\u id
。散列将仅用于查询和平衡碎片。当您创建id:“散列”索引时,它是常规的\u id:1索引之外的索引。是否有方法将现有的\u id:1索引替换为“\u id:“散列”?我已经创建了一个散列索引,但是默认的id
索引仍然存在,这会占用磁盘空间和RAM。