Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Crea un índice comodín en todos los campos

Puede crear un índice comodín que admita consultas sobre todos los campos posibles del documento. Los índices comodín admiten consultas sobre nombres de campo arbitrarios o desconocidos.

Para crear un índice comodín en todos los campos (excluyendo _id), utiliza el especificador comodín ($**) como la clave de índice:

db.<collection>.createIndex( { "$**": <sortOrder> } )

Solo utilice índices comodín cuando los campos que desea indexar 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 contiene nombres de campos arbitrarios que impiden los índices dirigidos, considera remodelar tu esquema para tener nombres de campos coherentes. Para obtener más información sobre los índices dirigidos, consulte Cree índices para respaldar sus consultas.

Crear una colección artwork que contenga los siguientes documentos:

db.artwork.insertMany( [
{
"name": "The Scream",
"artist": "Edvard Munch",
"style": "modern",
"themes": [ "humanity", "horror" ]
},
{
"name": "Acrobats",
"artist": {
"name": "Raoul Dufy",
"nationality": "French",
"yearBorn": 1877
},
"originalTitle": "Les acrobates",
"dimensions": [ 65, 49 ]
},
{
"name": "The Thinker",
"type": "sculpture",
"materials": [ "bronze" ],
"year": 1904
}
] )

Cada documento contiene detalles sobre la obra de arte. Los nombres de campo varían entre los documentos dependiendo de la información disponible sobre la pieza.

La siguiente operación crea un índice comodín en todos los campos de documentos en la colección artwork (excluyendo _id):

db.artwork.createIndex( { "$**" : 1 } )

Este índice admite consultas de un solo campo en cualquier campo de la colección. Si un documento contiene un documento incrustado o un arreglo, el índice comodín recorre el documento o arreglo y almacena el valor de todos los campos en el documento o arreglo.

Por ejemplo, el índice admite las siguientes consultas:

  • query:

    db.artwork.find( { "style": "modern" } )

    Salida:

    [
    {
    _id: ObjectId("6352c401b1fac2ee2e957f09"),
    name: 'The Scream',
    artist: 'Edvard Munch',
    style: 'modern',
    themes: [ 'humanity', 'horror' ]
    }
    ]
  • query:

    db.artwork.find( { "artist.nationality": "French" } )

    Salida:

    [
    {
    _id: ObjectId("6352c525b1fac2ee2e957f0d"),
    name: 'Acrobats',
    artist: { name: 'Raoul Dufy', nationality: 'French', yearBorn: 1877 },
    originalTitle: 'Les acrobates',
    dimensions: [ 65, 49 ]
    }
    ]
  • query:

    db.artwork.find( { "materials": "bronze" } )

    Salida:

    [
    {
    _id: ObjectId("6352c387b1fac2ee2e957f08"),
    name: 'The Thinker',
    type: 'sculpture',
    materials: [ 'bronze' ],
    year: 1904
    }
    ]

Para aprender a crear un índice comodín que proyecte campos específicos a cubrir, consulta las siguientes páginas:

Para obtener más información sobre los comportamientos de los índices comodín, consulte:

Volver

Incluye o excluye campos

En esta página