Si le faltan campos de clave de partición, puede establecer el campo clave de partición a
null. Si desea establecer el campo de clave de partición que falta en un valor que no seanull, consulte Cambiar el valor de la clave de partición de un documento.
Para realizar la actualización, puede usar las siguientes operaciones en un mongos:
| | |
|---|
| | Se puede usar solo para establecer el valor clave faltante en null. Se puede realizar dentro o fuera de una transacción. Se puede realizar como una escritura reintentable o no. Para requisitos adicionales, consulta el comando/método específico.
|
| | Se puede usar para establecer el valor de clave faltante en null o cualquier otro valor. La actualización para establecer los campos clave de partición que faltan debe cumplir uno de los siguientes requisitos: el filtro de la query contiene una condición de igualdad en la clave de partición completa en la query el filtro de la query contiene una coincidencia exacta en _id la actualización apunta a una única partición
Para establecerlo en un valor distinto denull, consulta Cambiar el valor de la clave de partición de un documento. Para requisitos adicionales, consulta el comando/método específico.
|
| | Se puede usar para establecer el valor de clave faltante en null o cualquier otro valor. Al establecer campos de clave de partición faltantes con un método que explícitamente actualiza solo un documento, la actualización debe cumplir con uno de los siguientes requisitos: el filtro de la query contiene una condición de igualdad en la clave de partición completa en la query el filtro de la query contiene una coincidencia exacta en _id la actualización apunta a una única partición
Se devuelven valores clave faltantes cuando se realiza la coincidencia en null. Para evitar actualizar un valor clave que sea null, incluya condiciones de query adicionales según corresponda. Para establecerlo en un valor distinto denull, consulta Cambiar el valor de la clave de partición de un documento. Para requisitos adicionales, consulta el comando/método específico.
|
| | Para establecer un valor a null, puedes especificar múltiples modificaciones de claves shard en la operación masiva. Al establecer campos de clave de partición faltantes con un método que explícitamente actualiza solo un documento, la actualización debe cumplir con uno de los siguientes requisitos: el filtro de la query contiene una condición de igualdad en la clave de partición completa en la query el filtro de la query contiene una coincidencia exacta en _id la actualización apunta a una única partición
Para establecerlo en un valor distinto denull, consulta Cambiar el valor de la clave de partición de un documento. Para requisitos adicionales, consulte el comando/método subyacente.
|
Considera una colección de sales que esté particionada por el campo location. Algunos documentos de la colección no tienen el campo location. Un campo ausente se considera igual que un valor nulo para el campo. Para establecer explícitamente estos campos en null, ejecuta el siguiente comando:
| db.sales.updateOne( |
| { _id: 12345, location: null }, |
| { $set: { location: null } } |
| ) |
Al establecer campos de clave de partición faltantes con db.collection.updateOne() u otro método que actualice explícitamente solo un documento, la actualización debe cumplir uno de los siguientes requisitos:
el filtro de la query contiene una condición de igualdad en la clave de partición completa en la query
el filtro de la query contiene una coincidencia exacta en _id
la actualización está dirigida a una única partición