Search query parser¶
As of version 0.3.0 SQLAlchemy-Searchable comes with built in search query parser. The search query parser is capable of parsing human readable search queries into PostgreSQL search query syntax.
Example: Search for articles containing ‘star’ and ‘wars’
The default operator is ‘and’, hence the following queries are essentially the same:
query = search(query, 'star wars') query2 = search(query, 'star and wars') assert query == query2
Searching for articles containing ‘star’ or ‘wars’
query = search(query, 'star or wars')
SQLAlchemy-Searchable search query parser supports negation operator. By default the negation operator is ‘-‘.
Example: Searching for article containing ‘star’ but not ‘wars’
query = search(query, 'star or -wars')
- Searching for articles containing ‘star’ and ‘wars’ or ‘luke’
query = search(query '(star wars) or luke')
Hyphens between words¶
SQLAlchemy-Searchable is smart enough to not convert hyphens between words to negation operators. Instead, it simply converts all hyphens between words to spaces.
Hence the following search queries are essentially the same:
query = search(query, 'star wars') query2 = search(query, 'star-wars')
Emails as search terms¶
PostgreSQL tsvectors handle email strings in a way that they don’t get split into multiple tsvector terms. As of version 0.7 SQLAlchemy-Searchable doesn’t handle emails this way by default, rather it splits the email into separate search terms. If you wish to override this behaviour you can use the remove_symbols configuration option.
# Tries to match 'john', 'fastmonkeys' and 'com' separately query = search(query, email@example.com')
If you wish to use only the query parser this can be achieved by invoking parse_search_query function. This function parses human readable search query into PostgreSQL specific format.
parse_search_query('(star wars) or luke') # (star:* & wars:*) | luke:*