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.3.tar.gz (34.2 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.3-py3-none-any.whl (15.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: postgres_fts_backend-0.0.3.tar.gz
  • Upload date:
  • Size: 34.2 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.3.tar.gz
Algorithm Hash digest
SHA256 fcabb3bb68371c9880370af6e797923a7682af9d79d565df4fc8e8485b9f99b4
MD5 75a90a5b376d5ab393ff719e6b9c690a
BLAKE2b-256 2c4d1dc71519b8576d5730c6df05fd3c2d70c3f8d31bbb42de0aa82d90c5d4a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for postgres_fts_backend-0.0.3.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.3-py3-none-any.whl.

File metadata

File hashes

Hashes for postgres_fts_backend-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 70c77be97bd2521a87284fc06941b58f3b79adbeb7c4d838bd977a343a2c175c
MD5 fe6fd4fcff9cf9ebb525e77eabeb4b26
BLAKE2b-256 5c0c9128b7aa63819017fae395b1ddb089cc048df41b30e0be5a5dbbb582b095

See more details on using hashes here.

Provenance

The following attestation bundles were made for postgres_fts_backend-0.0.3-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