Skip to main content

AI agent for PostgreSQL — ask questions about your database

Project description

Plugent

AI Agent for PostgreSQL — Ask natural language questions about your database and get intelligent answers powered by LLMs.

Plugent bridges the gap between natural language and SQL by using embeddings, vector search, and large language models (LLMs) to provide intuitive database interactions without writing SQL queries.

Features

  • 🤖 Natural Language Queries — Ask your database questions in plain English
  • 🔄 Automatic Vector Store Synchronization — Background scheduler keeps embeddings in sync with database changes
  • Fast Semantic Search — Uses FAISS for efficient vector similarity search across your data
  • 📊 Context-Aware Responses — Provides relevant database context to the LLM for accurate answers
  • 🔌 PostgreSQL Integration — Works seamlessly with PostgreSQL databases
  • 🚀 Production-Ready — Async-safe scheduler with configurable sync intervals

Installation

Install Plugent from PyPI:

pip install plugent

Prerequisites

  • Python 3.9 or higher
  • PostgreSQL database
  • Groq API key (get one free at groq.com)

Quick Start

from plugent import Plugent

# Initialize with your database and API credentials
plugent = Plugent(
    groq_api_key="your_groq_api_key",
    postgres_url="postgresql://user:password@localhost:5432/yourdb",
    vector_store_path="./my_vector_store",
    schedule_interval=60,
)

# Start the agent (connects to DB, builds vector store, starts background sync)
plugent.start()

# Ask natural language questions about your data
answer = plugent.ask("What are the most recent users in the database?")
print(answer)

# Stop the scheduler when done
plugent.stop()

Configuration

Parameters

Parameter Type Default Description
groq_api_key str required API key for Groq LLM service
postgres_url str required PostgreSQL connection string (format: postgresql://user:password@host:port/database)
vector_store_path str "./plugent_store" Directory path for saving/loading the FAISS vector store
schedule_interval int 60 Seconds between database synchronization checks

How It Works

Architecture Overview

Plugent operates through three main components:

  1. Database Reader — Connects to PostgreSQL and reads table schemas and data
  2. Embedder — Converts database rows and user queries into vector embeddings using fastembed
  3. Vector Store — Maintains a FAISS index for fast semantic search and retrieval

Workflow

  1. Initialization (start())

    • Connects to your PostgreSQL database
    • Reads all tables and rows
    • Generates embeddings for each row using fastembed (BAAI/bge-small-en-v1.5)
    • Builds a FAISS vector index
    • Saves the vector store to disk for reuse
    • Starts a background scheduler for continuous updates
  2. Query Processing (ask())

    • Embeds your natural language question
    • Searches the FAISS vector store for semantically relevant database rows
    • Retrieves the most relevant context
    • Sends the query + context to the Groq LLM
    • Returns the AI-generated answer
  3. Background Synchronization

    • Periodically checks PostgreSQL for new, modified, or deleted rows
    • Updates the vector store with changes
    • Keeps embeddings fresh and in sync with your database

Development

Running Tests

Run the test suite with pytest:

pytest tests/

Run specific tests:

pytest tests/test_core.py -v

Project Structure

plugent/
├── core.py           # Main Plugent class
├── db_reader.py      # PostgreSQL connector
├── embedder.py       # Embedding generation
├── responder.py      # LLM response handler
├── retriever.py      # Vector search retriever
├── scheduler.py      # Background task scheduler
└── vector_store.py   # FAISS vector store management

Requirements

  • sentence-transformers — For generating embeddings
  • FAISS — For vector similarity search
  • psycopg2 — PostgreSQL adapter
  • SQLAlchemy — SQL toolkit and ORM
  • APScheduler — Background task scheduler
  • Groq — LLM API client

License

MIT License — see LICENSE for details

Contributing

Contributions are welcome! Please feel free to submit pull requests or open issues for bug reports and feature requests.

Support

For issues, questions, or feedback, please open an issue on GitHub.


Note: Ensure your PostgreSQL connection string is secure and never commit API keys to version control. Use environment variables for sensitive credentials.

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

plugent-0.2.3.tar.gz (10.5 kB view details)

Uploaded Source

Built Distribution

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

plugent-0.2.3-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file plugent-0.2.3.tar.gz.

File metadata

  • Download URL: plugent-0.2.3.tar.gz
  • Upload date:
  • Size: 10.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for plugent-0.2.3.tar.gz
Algorithm Hash digest
SHA256 5a8c28bad9ddba62883bb5a265d826fa7b0783dce9051ffaf2d0d869079e8755
MD5 cb7f8ed194816e1222a4c6b722a4cb69
BLAKE2b-256 98f44299248155da64b5946a58875c8cf974534f0fcff86fb702750ae3ebb9f2

See more details on using hashes here.

File details

Details for the file plugent-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: plugent-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for plugent-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 c47c87a6932c404c2ba5b6e2be113fcf6a01045a6b0eeb755bc10d0be6ad9264
MD5 310cf482b32ad9f3c71234e13c7259be
BLAKE2b-256 d8ebbebdb78ab81681d5c4cef2bbcae65a0bc6c9146cba712ec95285c79f14d3

See more details on using hashes here.

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