Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
Click here >
Docs Menu
Docs Home
/ /
Claves de partición

Establecer campos de clave de partición faltantes

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:

Comando
Método
Descripción
update with
multi: true
  • 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.

update with
multi: false
  • 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

Volver

Cambiar el valor de la clave de partición de un documento

En esta página