Los índices comodín en un solo campo admiten consultas en cualquier subcampo del campo indexado. Utilice índices comodín para admitir consultas sobre nombres de campos que no conoce con anticipación o que varían entre documentos.
Para crear un índice comodín en un solo campo, utiliza el
db.collection.createIndex() método e incluya el especificador comodín ($**) en la clave de índice:
db.collection.createIndex( { "<field>.$**": <sortOrder> } )
Acerca de esta tarea
Usa índices comodín solo cuando los campos a los que quieras aplicar un índice sean desconocidos o puedan cambiar. Los índices comodín no funcionan tan bien como los índices dirigidos en campos específicos. Si tu colección tiene nombres arbitrarios de campos que impiden los índices dirigidos, considera remodelar tu esquema para que tenga nombres de campo coherentes. Para aprender más sobre los índices objetivo, consulta Crear índices para dar soporte a tus query.
Antes de comenzar
Creá una colección products que contenga los siguientes documentos:
db.products.insertMany( [ { "product_name" : "Spy Coat", "attributes" : { "material" : [ "Tweed", "Wool", "Leather" ], "size" : { "length" : 72, "units" : "inches" } } }, { "product_name" : "Spy Pen", "attributes" : { "colors" : [ "Blue", "Black" ], "secret_feature" : { "name" : "laser", "power" : "1000", "units" : "watts", } } } ] )
Procedimiento
La siguiente operación crea un índice comodín en el campo attributes:
db.products.createIndex( { "attributes.$**" : 1 } )
Resultados
El índice comodín admite consultas de campo único en attributes o sus campos incrustados. Por ejemplo, el índice admite las siguientes queries:
query:
db.products.find( { "attributes.size.length" : { $gt : 60 } } ) Salida:
[ { _id: ObjectId("63472196b1fac2ee2e957ef6"), product_name: 'Spy Coat', attributes: { material: [ 'Tweed', 'Wool', 'Leather' ], size: { length: 72, units: 'inches' } } } ] query:
db.products.find( { "attributes.material" : "Leather" } ) Salida:
[ { _id: ObjectId("63472196b1fac2ee2e957ef6"), product_name: 'Spy Coat', attributes: { material: [ 'Tweed', 'Wool', 'Leather' ], size: { length: 72, units: 'inches' } } } ] query:
db.products.find( { "attributes.secret_feature.name" : "laser" }, { "_id": 0, "product_name": 1, "attributes.colors": 1 } ) Salida:
[ { product_name: 'Spy Pen', attributes: { colors: [ 'Blue', 'Black' ] } } ]
Los índices comodín tienen un comportamiento específico cuando el campo indexado contiene un objeto incrustado (por ejemplo, attributes.secret_feature). Para obtener más información, consulta Índices comodín en objetos y arreglos embebidos.
Obtén más información
Para obtener más información sobre los comportamientos y casos de uso de los índices comodín, consulta: