Join us Sept 17 at .local NYC! Use code WEB50 to save 50% on tickets. Learn more >
MongoDB Jokes
Docs Menu
Docs Home
/ /

How to Index String Fields For Faceted Search

You can use the MongoDB Search stringFacet type to index string fields for faceting, which allows you to run a facet operator query on that field. MongoDB Search doesn't apply the analyzer when indexing string fields for faceting.

MongoDB Search only supports facet operator queries against fields indexed as the stringFacet type. To perform a normal search also on the same field, you must index the field as type string also.

To facet on string fields in embedded documents, you must index the parent fields as the document type. When you facet on a string field inside embedded documents, MongoDB Search returns facet count for only the number of matching parent documents.

MongoDB Search doesn't dynamically index string values for faceting. You must use static mappings to index string values for faceting. You can use the Visual Editor or the JSON Editor in the Atlas UI to index string fields as the number type.

To define the index for the stringFacet type, choose your preferred configuration method in the Atlas UI and then select the database and collection.

  1. Click Refine Your Index to configure your index.

  2. In the Field Mappings section, click Add Field Mapping to open the Add Field Mapping window.

  3. Click Customized Configuration.

  4. Select the field to index from the Field Name dropdown.

    Note

    You can't index fields that contain the dollar ($) sign at the start of the field name.

  5. Click the Data Type dropdown and select StringFacet. To learn more more about this type, see Field Properties.

  6. Click Add.

The following is the JSON syntax for the stringFacet type. Replace the default index definition with the following. To learn more about the fields, see Field Properties.

{
"mappings": {
"dynamic": true|false,
"fields": {
"<field-name>": {
"type": "stringFacet"
}
}
}
}

The MongoDB Search stringFacet type has the following parameters:

UI Field Name
JSON Option
Type
Necessity
Description

Data Type

type

string

Required

Human-readable label that identifies this field type. Value must be stringFacet. MongoDB Search truncates BSON string values indexed as the stringFacet type to around 8000 UTF-16 code units.

The following index definition example uses the sample_mflix.movies collection. If you have the sample data already loaded on your cluster, you can use the Visual Editor or JSON Editor in the Atlas UI to configure the index. After you select your preferred configuration method, select the database and collection, and refine your index to add field mappings.

The following index definition for the sample_mflix.movies collection in the sample dataset indexes the genres field as stringFacet for faceting.

  1. In the Add Field Mapping window, select genres from the Field Name dropdown.

  2. Click the Data Type dropdown and select StringFacet.

  3. Click Add.

{
"mappings": {
"dynamic": false,
"fields": {
"genres": {
"type": "stringFacet"
}
}
}
}

The following index definition for the sample_mflix.movies collection in the sample dataset indexes the genres field as stringFacet and string types to return the following types of results for your queries:

  1. In the Add Field Mapping window, select genres from the Field Name dropdown.

  2. Click the Data Type dropdown and select StringFacet.

  3. Click Add.

  4. Repeat step 1 and select String from the Data Type dropdown.

  5. Review the default setting for String Properties and click Add.

{
"mappings": {
"dynamic": false,
"fields": {
"genres": [
{
"type": "stringFacet"
},
{
"type": "string"
}
]
}
}
}

To learn more about the facet collector and see example queries, see Examples.

To learn how to create an index with a facet definition and query that index using the facet collector, see the How to Use Facets with MongoDB Search tutorial.

To see an example index and query that uses stringFacet to run a faceted search with paginated results, see Use Facet with the Paginated Results.

Back

string

On this page