Menu Docs
Página inicial do Docs
/ /

Coleções fragmentadas com índices únicos

Í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.

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:

1

Crie o índice que você planeja usar como chave de fragmento:

db.names.createIndex( { region_id: 1 } )
region_id_1
2

Crie o índice único para a collection. Inclua a chave de fragmentação como prefixo do índice:

db.names.createIndex(
{ region_id: 1, email: 1 },
{ unique: true }
)
region_id_1_email_1
3
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 } )
}

Voltar

Converter para Unique