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.1.tar.gz (25.6 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.1-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: postgres_fts_backend-0.0.1.tar.gz
  • Upload date:
  • Size: 25.6 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.1.tar.gz
Algorithm Hash digest
SHA256 d836dfd57f037686124a936bb6218f91334d07da96fad4334d4f8ca4b2dd72ad
MD5 51be3147a1f6c6ea4b6087b91f01e02b
BLAKE2b-256 880a3f8816483c006e0101b621a909d707221eba92b5699284d15d533d8c5b54

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for postgres_fts_backend-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 351d2de0ffdc64f0bb6ed232128812cfdcf08c39ea8813ba9a7a2c472f1781bb
MD5 e30e73662596d9013a9145973aecb966
BLAKE2b-256 bb9dd75f743ee370c6bc2cd15ddb9f6300a141226e7809c8f870b568d63e871b

See more details on using hashes here.

Provenance

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