Overview
The path parameter is used by the MongoDB Search
operators to specify the field or fields
to be searched. It may contain:
A string
An array of strings
A multi analyzer specification
An array containing a combination of strings and multi analyzer specifications
Note
Not all operators can use all the different types of paths. See the documentation for each individual operator for details on what types of path it supports.
Usage
To search only a single indexed field, use a quoted string in the
path parameter. The following example searches a field named
description.
"path": "description"
To search multiple indexed fields, use an array of quoted strings
in the path parameter. Documents which match on any of the
specified fields are included in the result set. The following
example searches the description and type fields.
"path": [ "description", "type" ]
Note
The multi path option is available only to fields of
type string.
If your index definition contains a field
with multiple analyzers, you can specify which one to use. The path
parameter can take an object with the following fields:
Field | Description |
|---|---|
| The name of the field to search. |
| The name of the alternate analyzer specified in a |
| The object containing the wildcard character
Wildcard path is only accepted by the following operators: Wildcard path is also accepted for highlighting. |
In the following index definition, fields named names and notes
use the standard analyzer.
A field named comments uses standard as its default analyzer,
and it also specifies a multi named mySecondaryAnalyzer which
uses the lucene.whitespace analyzer.
{ "mappings": { "dynamic": false, "fields": { "names": { "type": "string", "analyzer": "lucene.standard" }, "notes": { "type": "string", "analyzer": "lucene.standard" }, "comments": { "type": "string", "analyzer": "lucene.standard", "multi": { "mySecondaryAnalyzer": { "analyzer": "lucene.whitespace", "type": "string" } } } } } }
The following path example searches the comments field using
the multi named mySecondaryAnalyzer in the index definition.
"path": { "value": "comments", "multi": "mySecondaryAnalyzer" }
To search a combination of indexed fields and fields with multiple
analyzers, use an array. The following example searches the
names and notes fields with the default analyzer, and the
comments field using the multi named
mySecondaryAnalyzer in the index definition.
"path": [ "names", "notes", { "value": "comments", "multi": "mySecondaryAnalyzer" } ]
The following path example searches all the fields that contain the
letter n followed by any characters, and the comments field
using the multi named mySecondaryAnalyzer in the index
definition.
"path": [{ "wildcard": "n*" }, { "value": "comments", "multi": "mySecondaryAnalyzer" }]
Examples
The following examples use a collection named cars which has the
following documents:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Blue four-door sedan, lots of trunk space. Three to four passengers." } { "_id" : 2, "type" : "coupe", "make" : "BMW", "description" : "Red two-door convertible, driver's-side airbag." } { "_id" : 3, "type" : "SUV", "make" : "Ford", "description" : "Black four-door SUV, three rows of seats." }
Static field mappings allow you to specify how individual fields within a collection should be indexed and searched.
The index definition for the cars collection is as follows:
{ "mappings": { "dynamic": false, "fields": { "make": { "type": "string", "analyzer": "lucene.standard" }, "description": { "type": "string", "analyzer": "lucene.standard", "multi": { "simpleAnalyzer": { "analyzer": "lucene.simple", "type": "string" } } } } } }
The preceding index definition specifies that the make field is
indexed with the standard analyzer.
The description field uses the standard analyzer by
default, but it can also use the simple analyzer by specifying simpleAnalyzer with the
multi parameter.
Single Field Search
The following example searches for the string Ford in the
make field:
db.cars.aggregate([ { $search: { "text": { "query": "Ford", "path": "make" } } } ])
The preceding example returns the document with _id: 3.
Multiple Field Search
The following example uses an array of fields in the path
parameter to search for the string blue in either the make
or the description field.
db.cars.aggregate([ { $search: { "text": { "query": "blue", "path": [ "make", "description" ] } } } ])
The preceding query returns the following result:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Blue four-door sedan, lots of trunk space. Three to four passengers." }
Alternate Analyzer Search
Simple Analyzer Example
The following example uses the multi named simpleAnalyzer
in the index definition, which uses the simple analyzer.
The query searches the description field for the string driver.
db.cars.aggregate([ { $search: { "text": { "query": "driver", "path": { "value": "description", "multi": "simpleAnalyzer" } } } } ])
The preceding query returns the following result:
{ "_id" : 2, "type" : "coupe", "make" : "BMW", "description" : "Red two-door convertible, driver's-side airbag." }
The simple analyzer indexes driver's
side airbag as [driver s side airbag], so it matches on driver.
By contrast, the default standard analyzer
indexes driver's side airbag as [driver's side airbag], so it would
match on driver's or side but not driver.
Whitespace Analyzer Example
Suppose the multi object in the index definition for the cars
collection is the following:
"multi": { "simpleAnalyzer": { "analyzer": "lucene.whitespace", "type": "string" } }
The following example uses the multi named simpleAnalyzer
in the index definition, which uses the whitespace analyzer.
db.cars.aggregate([ { $search: { "text": { "query": "Three", "path": { "value": "description", "multi": "simpleAnalyzer" } } } } ])
The preceding query returns the following result:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Blue four-door sedan, lots of trunk space. Three to four passengers." }
For the above query on the term Three, MongoDB Search only returns documents
matching the term Three and not three becuase the
whitespace analyzer is case-sensitive. By
contrast, the default standard analyzer is
not case-sensitive and returns all documents matching the term in the
query in the order that they are listed in the collection.
Now, consider the following query:
db.cars.aggregate([ { $search: { "compound": { "should": [ { "text": { "path": "description", "query": "Three" } }, { "text": { "query": "Three", "path": { "value" : "description", "multi" : "simpleAnalyzer" }, score: { boost: { value: 2 }} } } ] } } }, { $project: { "_id": 0, "type": 1, "description": 1, "score": { "$meta": "searchScore" } } } ])
The preceding query returns the following results:
{ "type" : "sedan", "description" : "Blue four-door sedan, lots of trunk space. Three to four passengers seats.", "score" : 1.1092689037322998 } { "type" : "SUV", "description" : "Black four-door SUV, three rows of seats.", "score" : 0.17812025547027588 }
For the above query, MongoDB Search returns documents with both Three and
three. However, the score of the result with Three is higher
because while the document with three was matched using the default
standard analyzer, the document with
Three was matched by both the specified simpleAnalyzer and the
default standard analyzer.
The following example uses a collection called posts with the
following documents:
{ "_id": 1, "username": "pinto", "post": { "date": "12-03-2018", "forum": "Tofu Recipes", "body": "Spicy Garlic Tofu cooks up crispy in 10 minutes or less. Serve with broccoli and rice for a delicious vegetarian meal." } } { "_id": 2, "username": "paloma", "post": { "date": "12-08-2018", "forum": "Tofu Recipes", "body": "Crispy Tofu in Shiitake Broth has flavors of citrus and umami. Great as an appetizer or entree." } }
Dynamic field mappings allow you to index all fields in a collection as needed.
The index definition for the posts collection is as follows:
{ "mappings": { "dynamic": true } }
Nested Field Search
The following compound operator query searches the field
post.body for the string broccoli, and also specifies that the
field must not contain the string cauliflower.
db.posts.aggregate([ { $search: { "compound": { "must": { "text": { "query": "broccoli", "path": "post.body" } }, "mustNot": { "text": { "query": "cauliflower", "path": "post.body" } } } } } ])
The preceding query returns the document with _id: 1, in which the
posts.body field contains the string broccoli.
Wildcard Field Search
The following example uses a collection named cars, which has the following documents:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Four-door sedan, lots of trunk space. Three to four passengers.", "warehouse" : [ { "inventory" : 3, "color" : "red" } ] } { "_id" : 2, "type" : "coupe", "make" : "BMW", "description" : "Two-door convertible, driver's-side airbag.", "warehouse" : [ { "inventory" : 5, "color" : "black" } ] } { "_id" : 3, "type" : "SUV", "make" : "Ford", "description" : "Four-door SUV, three rows of seats.", "warehouse" : [ { "inventory" : 7, "color" : "white" }, { "inventory" : 3, "color" : "red" } ] }
The index definition for the cars collection is as follows:
{ "mappings": { "dynamic": true } }
The following queries search the fields specified using the wildcard character
* for the string red.
All Fields Search Example
The following query searches all fields for the
string red.
db.cars.aggregate([ { "$search": { "phrase": { "path": { "wildcard": "*" }, "query": "red" } } } ])
The query returns the following results:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Four-door sedan, lots of trunk space. Three to four passengers.", "warehouse" : [ { "inventory" : 3, "color" : "red" } ] } { "_id" : 3, "type" : "SUV", "make" : "Ford", "description" : "Four-door SUV, three rows of seats.", "warehouse" : [ { "inventory" : 7, "color" : "white" }, { "inventory" : 3, "color" : "red" } ] }
Nested Field Search Example
The following query searches the fields nested
within the warehouse field for the string red.
db.cars.aggregate([ { "$search": { "text": { "path": { "wildcard": "warehouse.*" }, "query": "red" } } } ])
The query returns the following results:
{ "_id" : 1, "type" : "sedan", "make" : "Toyota", "description" : "Four-door sedan, lots of trunk space. Three to four passengers.", "warehouse" : [ { "inventory" : 3, "color" : "red" } ] } { "_id" : 3, "type" : "SUV", "make" : "Ford", "description" : "Four-door SUV, three rows of seats.", "warehouse" : [ { "inventory" : 7, "color" : "white" }, { "inventory" : 3, "color" : "red" } ] }