Search with facets

    In Meilisearch, facets are a specialized type of filter. This guide shows you how to configure facets and use them when searching a database of books. It also gives you instruction on how to get

    Requirements

    Configure facet index settings

    First, create a new index using this books dataset. Documents in this dataset have the following fields:

    {
      "id": 5,
      "title": "Hard Times",
      "genres": ["Classics","Fiction", "Victorian", "Literature"],
      "publisher": "Penguin Classics",
      "language": "English",
      "author": "Charles Dickens",
      "description": "Hard Times is a novel of social […] ",
      "format": "Hardcover",
      "rating": 3
    }
    

    Next, add genres, language, and rating to the list of filterableAttributes:

    curl \
      -X PUT 'MEILISEARCH_URL/indexes/books/settings/filterable-attributes' \
      -H 'Content-Type: application/json' \
      --data-binary '[
        "genres", "rating", "language"
      ]'

    You have now configured your index to use these attributes as filters.

    Use facets in a search query

    Make a search query setting the facets search parameter:

    curl \
      -X POST 'MEILISEARCH_URL/indexes/books/search' \
      -H 'Content-Type: application/json' \
      --data-binary '{
        "q": "classic",
        "facets": [
        "genres", "rating", "language"
      ]
    }'

    The response returns all books matching the query. It also returns two fields you can use to create a faceted search interface, facetDistribution and facetStats:

    {
      "hits": [],"facetDistribution": {
        "genres": {
          "Classics": 6,},
        "language": {
          "English": 6,
          "French": 1,
          "Spanish": 1
        },
        "rating": {
          "2.5": 1,}
      },
      "facetStats": {
        "rating": {
          "min": 2.5,
          "max": 4.7
        }
      }
    }
    

    facetDistribution lists all facets present in your search results, along with the number of documents returned for each facet.

    facetStats contains the highest and lowest values for all facets containing numeric values.

    Sorting facet values

    By default, all facet values are sorted in ascending alphanumeric order. You can change this using the sortFacetValuesBy property of the faceting index settings:

    curl \
      -X PATCH 'MEILISEARCH_URL/indexes/books/settings/faceting' \
      -H 'Content-Type: application/json' \
      --data-binary '{
        "sortFacetValuesBy": {
          "genres": "count"
      }
    }'

    The above code sample sorts the genres facet by descending value count.

    Repeating the previous query using the new settings will result in a different order in facetsDistribution:

    {"facetDistribution": {
        "genres": {
          "Fiction": 8,
          "Literature": 7,
          "Classics": 6,
          "Novel": 2,
          "Horror": 2,
          "Fantasy": 2,
          "Victorian": 2,
          "Vampires": 1,
          "Tragedy": 1,
          "Satire": 1,
          "Romance": 1,
          "Historical Fiction": 1,
          "Coming-of-Age": 1,
          "Comedy": 1
        },}
    }
    

    Searching facet values

    You can also search for facet values with the facet search endpoint:

    curl \
      -X POST 'MEILISEARCH_URL/indexes/books/facet-search' \
      -H 'Content-Type: application/json' \
      --data-binary '{
        "facetQuery": "c",
        "facetName": "genres"
    }'

    The following code sample searches the genres facet for values starting with c:

    The response contains a facetHits array listing all matching facets, together with the total number of documents that include that facet:

    {"facetHits": [
        {
          "value": "Children's Literature",
          "count": 1
        },
        {
          "value": "Classics",
          "count": 6
        },
        {
          "value": "Comedy",
          "count": 2
        },
        {
          "value": "Coming-of-Age",
          "count": 1
        }
      ],
      "facetQuery": "c",}
    

    You can further refine results using the q, filter, and matchingStrategy parameters. Learn more about them in the API reference.