Docs Menu
Docs Home
/ /

一意なインデックスを持つシャーディングされたコレクション

シャーディングされたコレクションでは、インデックスがシャードキーであるか、それがプレフィックスとして含まれていない限り、サポートされません。

インデックスに一意の制約を適用すると、コレクション内のドキュメントがフィールドに一意の値が設定されるようになります。シャーディングされたコレクションでは、インデックスがシャードキーであるか、プレフィックスとしてシャードキーが含まれていない限り、 MongoDB はフィールドに一意の制約を強制しません。問題を防ぐ方法は、次のとおりです。

1

シャードキーとして使用するインデックスを作成します。

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

コレクションのユニークインデックスを作成します。インデックスのプレフィックスとしてシャードキーを含めます。

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 } )
}

戻る

一意への変換