Restricciones de clave únicas de Azure Cosmos DB
SE APLICA A: NoSQL
Las claves únicas agregan una capa de integridad de datos a un contenedor de Azure Cosmos DB. Cree una directiva de clave única cuando cree un contenedor de Azure Cosmos DB. Con las claves únicas, se garantiza que uno o varios valores dentro de una partición lógica son únicos. También puede garantizar la exclusividad por clave de partición.
Después de crear un contenedor con una directiva de clave única, se impide la creación de una versión nueva o actualizada de un elemento existente que dé lugar a un elemento duplicado en una partición lógica, según especifique la restricción de clave única. La clave de partición combinada con la clave única garantiza la exclusividad de un elemento dentro del ámbito del contenedor.
Por ejemplo, considere un contenedor de Azure Cosmos DB con Email address
como restricción de clave única y CompanyID
como clave de partición. Cuando configura la dirección de correo electrónico del usuario con una clave única, cada elemento tiene una dirección de correo electrónico única dentro de un ámbito CompanyID
determinado. No se pueden crear dos elementos con direcciones de correo electrónico duplicadas y con el mismo valor de clave de partición. En la API para NoSQL de Azure Cosmos DB, los elementos se almacenan como valores JSON. Los valores JSON distinguen entre mayúsculas y minúsculas. Al elegir una propiedad como clave única, puede insertar valores que distinguen mayúsculas de minúsculas para esa propiedad. Por ejemplo, si tiene una clave única definida en la propiedad name, "Gaby" es diferente a "gaby" y se pueden insertar ambos en el contenedor.
Para crear elementos con la misma dirección de correo electrónico, pero no con el mismo nombre, apellidos y dirección de correo electrónico, agregue otras rutas de acceso a la directiva de claves únicas. En lugar de crear una clave única basada solo en la dirección de correo electrónico, puede crear también una clave única con una combinación de nombre, apellido y correo electrónico. Esta clave se conoce como clave única compuesta. En este caso, se permite cada combinación única de los tres valores dentro de un ámbito CompanyID
determinado.
Por ejemplo, el contenedor puede contener elementos con los valores siguientes, donde cada elemento respeta la restricción de clave única.
CompanyID | Nombre | Apellido | Dirección de correo electrónico |
---|---|---|---|
Contoso | Gaby | Duperre | gaby@contoso.com |
Contoso | Gaby | Duperre | gaby@fabrikam.com |
Fabrikam | Gaby | Duperre | gaby@fabrikam.com |
Fabrikam | Ivan | Duperre | gaby@fabrikam.com |
Fabrikam | Duperre | gaby@fabraikam.com | |
Fabrikam | gaby@fabraikam.com |
Si intenta insertar otro elemento con las combinaciones que aparecen en la tabla anterior, recibirá un error. El error indica que no se ha cumplido con la restricción de clave única. Recibir Resource with specified ID or name already exists
o Resource with specified ID, name, or unique index already exists
como un mensaje devuelto.
Definición de una clave única
Puede definir claves únicas solo cuando se crea un contenedor de Azure Cosmos DB. Una clave única se limita a una partición lógica. En el ejemplo anterior, si crea particiones del contenedor según el código postal, puede tener los mismos elementos en cada partición lógica. Tenga en cuenta las siguientes propiedades al crear claves únicas:
No puede actualizar un contenedor existente para que use una clave única distinta. En otras palabras, una vez creado un contenedor con una directiva de clave única, la directiva no se puede cambiar.
Para establecer una clave única para un contenedor existente, cree un nuevo contenedor con la restricción de clave única. Utilice la herramienta de migración de datos adecuada para mover los datos desde el contenedor existente al nuevo contenedor. En el caso de los contenedores de SQL, use los trabajos de copia de contenedor para mover datos. Para los contenedores de MongoDB, utilice mongoimport.exe o mongorestore.exe para mover los datos.
Una directiva de clave única puede tener un máximo de 16 valores de ruta de acceso. Por ejemplo, los valores pueden ser
/firstName
,/lastName
y/address/zipCode
. Cada directiva de clave única puede tener un máximo de 10 restricciones o combinaciones de clave única. En el ejemplo anterior, el nombre, el apellido y la dirección de correo electrónico de forma conjunta constituyen solo una restricción. Esta restricción utiliza tres de las dieciséis posibles rutas de acceso.Cuando un contenedor tiene una directiva de clave única, los cargos de unidad de solicitud para crear, actualizar y eliminar un elemento son ligeramente superiores.
No se admiten las claves únicas dispersas. Si faltan algunos valores de ruta de acceso única, se tratan como valores NULL, que participan en la restricción de exclusividad. Por este motivo, solo puede haber un único elemento con un valor NULL para cumplir esta restricción.
Los nombres de clave única distinguen mayúsculas de minúsculas. Por ejemplo, considere un contenedor con la restricción de clave única establecida en
/address/zipcode
. Si los datos tienen un campo denominadoZipCode
, Azure Cosmos DB inserta "null" como clave única porquezipcode
no es lo mismo queZipCode
. Debido a esta distinción entre mayúsculas y minúsculas, todos los demás registros con "Código Postal" no se podrán insertar porque un valor "null" duplicado infringirá la restricción de clave única.
Pasos siguientes
- Más información sobre las particiones lógicas
- Explorar cómo definir claves únicas al crear un contenedor
- ¿Intenta planear la capacidad de una migración a Azure Cosmos DB? Para ello, puede usar información sobre el clúster de bases de datos existente.
- Si lo único que sabe es el número de núcleos virtuales y servidores del clúster de bases de datos existente, lea sobre el cálculo de unidades de solicitud mediante núcleos o CPU virtuales.
- Si conoce las tasas de solicitudes típicas de la carga de trabajo de la base de datos actual, obtenga información sobre el cálculo de unidades de solicitud mediante la herramienta de planeamiento de capacidad de Azure Cosmos DB.