Índices únicos não são suportados em collections fragmentadas a menos que o índice seja a chave de shard ou a inclua como um prefixo.
Sobre esta tarefa
A restrição de exclusividade em um índice garante que os documentos na coleta tenham um valor exclusivo definido no campo. Com collections fragmentadas, o MongoDB não impõe a restrição de exclusividade no campo , a menos que o índice seja a chave de fragmentação ou inclua a chave de fragmentação como prefixo. Para evitar problemas:
Em uma collection fragmentada, se você criar um índice único que não use a chave de shard, o MongoDB retornará um erro para o
createIndexescomando.Se você fragmentar uma collection e a collection contiver um índice único que não utilize a chave de shard, o MongoDB retornará um erro para o
shardCollectioncomando.
Passos
Fragmentar a collection
sh.shardCollection( "accounts.names", { region_id: 1 } )
{ collectionsharded: 'accounts.names', ok: 1, '$clusterTime': { clusterTime: Timestamp( { t: 1759260515, i: 58 } ), signature: { hash: Binary.createFromBase64( 'AAAAAAAAAAAAAAAAAAAAAAAAAAA=', 0 ), keyId: Long( '0' ) } }, operationTime: Timestamp( { t: 1759260515, i: 57 } ) }