ElasticGraph Query API: Full Text Search
ElasticGraph supports two full-text search filtering predicates:
matchesPhrase
- Matches records where the field value has a phrase matching the provided phrase using
full text search. This is stricter than
matchesQuery
: all terms must match and be in the same order as the provided phrase.When
null
is passed, matches all documents. matchesQuery
- Matches records where the field value matches the provided query using full text search.
This is more lenient than
matchesPhrase
: the order of terms is ignored, and, by default, only one search term is required to be in the field value.When
null
is passed, matches all documents.
Matches Query
matchesQuery
is the more lenient of the two predicates. It’s designed to match broadly. Here’s an example:
This query will match artists with bios like:
Renowned for his mesmerizing performances, Luca “The Breeze” Fontana captivates audiences with his accordion, weaving intricate melodies that dance between the notes of traditional folk and modern jazz.
Sylvia Varela’s avant-garde violin playing defies tradition, blending haunting dissonance with unexpected rhythms.
Notably, the description needs accordion
OR violin
, but not both. In addition, it would match an artist bio that
mentioned “viola” since it supports fuzzy matching by default and “viola” is only 2 edits away from “violin”. Arguments
are supported to control both aspects to make matching stricter:
Matches Phrase
matchesPhrase
is even stricter: it requires all terms in the provided order (matchesQuery
doesn’t care about order). It’s particularly useful when you want to search on a particular multi-word expression:
Bypassing matchesPhrase and matchesQuery
In order to make a matchesPhrase
or matchesQuery
filter optional, you can supply null
to the MatchesQueryFilterInput
parameter, like this: