Skip to main content

A PostgreSQL Full Text Seach Backend for Haystack

Project description

postgres-fts-backend

A Django Haystack backend that uses PostgreSQL's built-in full-text search. No external search service required.

Requirements

  • Python >= 3.12
  • Django >= 5.0
  • django-haystack >= 2.8.0
  • PostgreSQL

Installation

pip install postgres-fts-backend

Add to INSTALLED_APPS:

INSTALLED_APPS = [
    "django.contrib.postgres",
    "haystack",
    "postgres_fts_backend",
    # ...
]

Set a migration module so the generated search index migrations live in your project rather than inside the installed package:

MIGRATION_MODULES = {
    "postgres_fts_backend": "myapp.search_migrations",
}

Configure Haystack:

HAYSTACK_CONNECTIONS = {
    "default": {
        "ENGINE": "postgres_fts_backend.PostgresFTSEngine",
    },
}

To use a search configuration other than "english":

HAYSTACK_CONNECTIONS = {
    "default": {
        "ENGINE": "postgres_fts_backend.PostgresFTSEngine",
        "SEARCH_CONFIG": "spanish",
    },
}

Other Peculiarities of this backend

Build indexes through models and migrations

python manage.py build_postgres_schema
python manage.py migrate postgres_fts_backend

Run these two commands again whenever you change a SearchIndex definition.

Fuzzy search

Fuzzy queries use PostgreSQL's trigram similarity matching (pg_trgm):

results = SearchQuerySet().filter(author__fuzzy="Janee")

The similarity threshold is controlled by PostgreSQL's pg_trgm.similarity_threshold setting (default 0.3). To adjust it:

ALTER DATABASE mydb SET pg_trgm.similarity_threshold = 0.5;

more_like_this not implemented

PostgreSQL FTS doesn't provide any facilities for this. It could be done, but I just need to think more about it.

spelling_suggestions are not supported

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

postgres_fts_backend-0.0.2.tar.gz (31.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

postgres_fts_backend-0.0.2-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file postgres_fts_backend-0.0.2.tar.gz.

File metadata

  • Download URL: postgres_fts_backend-0.0.2.tar.gz
  • Upload date:
  • Size: 31.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for postgres_fts_backend-0.0.2.tar.gz
Algorithm Hash digest
SHA256 b902cc65a8bec2133f2357145e3c6d8dbaf8b3414ea34df17b8a0471abdcb0ee
MD5 9308a71b934c70a11c13e46bc5a47327
BLAKE2b-256 c46b6878f6728e546a145c17d5e61c988b9a632b158a53154734e7fc0b128f40

See more details on using hashes here.

Provenance

The following attestation bundles were made for postgres_fts_backend-0.0.2.tar.gz:

Publisher: release.yml on fgregg/postgres-fts-backend

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file postgres_fts_backend-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for postgres_fts_backend-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 496ca86e53069e1bae6f0798d3c159b4fa8a70d8d6c5bc0d58b385600e4b5968
MD5 fc83812d4fc89b3b47b7495c07b7fb5e
BLAKE2b-256 7eb6833974fd61c1dea5476c8cda5b6dee3851188be677388f1ae2106936481e

See more details on using hashes here.

Provenance

The following attestation bundles were made for postgres_fts_backend-0.0.2-py3-none-any.whl:

Publisher: release.yml on fgregg/postgres-fts-backend

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page