Skip to content

Filters

Search results can optionally be filtered and these filters are applied to the search hits at the very end of a search request, after all facets have already been calculated and don’t influence facet counts any more.

# The following example search request filters products of a certain color “Black” OR "Blue" AND price between 100 USD inclusive TO 200 USD exlusive AND name starts with "ASUS ZenFone 2"
{
  products(filter: "color:Black,Blue price.usd:[100 TO 200) name:\"ASUS ZenFone 2*\" {
      totalCount
      items
      {
        name
        properties
        {
            name
            values
        }
      }
  }
}

Terms

A query is broken up into terms and operators. There are two types of terms: Single Terms and Phrases. A Single Term is a single word such as "test" or "hello". A Phrase is a group of words surrounded by double quotes such as "hello dolly". Multiple terms can be combined together with Boolean operators to form a more complex query (see below).

Fields

When performing a search you can either specify a field by typing the field name followed by a colon ":" and then the term you are looking for.

name:"My cool name" color:Black

Specifying multiple values in one field parameter, separated by a comma, will return products in which at least one of the specified values matches (OR-operator). The example search request below filters products of the color “black” OR “grey” or "blue":

color:Black,Gey,Blue

Range Filtration

Range filtration allow one to match products whose field(s) values are between the lower and upper bound specified by the Range expression. Range filter expression can be inclusive or exclusive of the upper and lower bounds. Sorting is done lexicographically.

price:[100 TO 200]

This will find products whose prices have values between 100 and 200, inclusive. Inclusive range queries are denoted by square brackets. Exclusive range queries are denoted by round brackets.

price:(100 TO 200]

This will find products whose prices have values between 100 exclusive and 200 inclusive.

You can skip one of the values to ignore either the lower or the upper bound

price:(TO 100]

where the price is less than or equal to 100

Boolean Operators

Passing multiple field terms in the one filter expression separated by space delimiter will combine them with an AND operator.

The following example search request filters products of a certain brand "Onkyo" AND of the color “Black”.

color:Black brand:Onkyo

[!CAUTION] At the moment only AND logical operator is supported for filter expressions.

Wildcard Searches

You can use single and multiple character wildcard searches within single or phrase terms. To perform a single character wildcard search use the ? symbol. To perform a multiple character wildcard search use the * symbol.

te?t

Multiple character wildcard searches looks for 0 or more characters.

For example, to search for test, tests or tester, you can use the search:

test*

You can also use the wildcard searches in the middle of a term.

te*t

Escaping Special Characters

Inside the double quotes block you might use any unsafe characters, to escape double quote character use the \. See more details GraphQL String-Value

\"my cool property\":\"&~!'\"

When term value contains " or \, these characters are escaped twice.

Field name: my property

Field value: value with \ and " in the middle

  1. Building the term filter:

"my property":"value with \\ and \" in the middle"

  1. Putting this term filter into the GraphQL filter:

filter:"\"my property\":\"value with \\\\ and \\\" in the middle\""

More examples

color:Black,White

where the color is 'Black' OR 'White'

color:Black color:White

where the color is 'Black' AND 'White'

price_usd:[100 TO 200]

where the price is in USD and between values including bounds

price:(100 TO 200)

where the price is in any currency and between values excluding bounds

price:(0 TO)

where the price is greater than zero

price:(TO 100]

where the price is less than or equal to 100

Da?? Red*

use ? to replace a single character, and * to replace zero or more characters

color:Black price:[100 TO 200)

combine keywords and filters


Last update: February 1, 2024