Pg-sphinx is an extension for PostgreSQL which allows to integrate Sphinx search engine.
make
sudo make install
Superuser is required.
echo 'CREATE EXTENSION sphinx;' | psql -U postgres mydatabase
sudo make uninstall
Extension can be configured by modifying corresponding rows in table sphinx_config. Following options are available: ‘host’, ‘post’, ‘username’, ‘password’, ‘prefix’.
‘Prefix’ is a string which is prepended to index names. This option is useful to simulate namespaces. For example, if prefix is ‘test_’ and index name in a request is ‘blog_posts’, real request will be addressed to index named ‘test_blog_posts’.
sphinx_select(
/*index*/ varchar,
/*query*/ varchar,
/*condition*/ varchar,
/*order*/ varchar,
/*offset*/ int,
/*limit*/ int,
/*options*/ varchar)
Returns pairs (id, weight).
sphinx_replace(
/*index*/ varchar,
/*id*/ int,
/*data*/ varchar[])
Updates document with specified id. Data array must have following format: ARRAY[‘key1’, ‘value2’, …]
sphinx_delete(
/*index*/ varchar,
/*id*/ int)
Removes specified document.
sphinx_snippet(
/*index*/ varchar,
/*query*/ varchar,
/*data*/ varchar,
/*before*/ varchar,
/*after*/ varchar)
Returns snippets for a given data and search query.
Example:
SELECT sphinx_snippet('blog_posts', 'photo', 'There are photos from monday meeting', '<b>', '</b>')
This query will return following text:
'There are <b>photos</b> from monday meeting'
sphinx_snippet_options(
/*index*/ varchar,
/*query*/ varchar,
/*data*/ varchar,
/*options*/ varchar[])
Returns snippets for a given data and search query. This function is similar to sphinx_snippet but it also accepts a list of additional options.
Because of array type limitations all values must be represented as text. Integer values have to be represented as decimal values (e. g. ‘19’). For boolean values ‘1’, ‘t’, ‘true’, ‘y’, and ‘yes’ are recognized as true, any other value is considered as false.
Example (similar to previous one):
SELECT sphinx_snippet_options('blog_posts', 'photo', 'There are photos from monday meeting',
ARRAY['before_match', '<b>',
'after_match', '</b>'])
One more example:
SELECT sphinx_snippet_options('blog_posts', 'photo', 'There are photos from monday meeting',
ARRAY['before_match', '<b>',
'after_match', '</b>',
'query_mode', 'yes'])