LLM-powered chat interface to your Postgres database - (psql powered with Natural Language)
Project description
psqlomni
(psql powered with natural language)
An LLM-powered chat interface to your database. This tool understands Postgres syntax and can easily translate English queries into proper SQL queries. Uses Langchain and Open AI model.
This provides the quickest way to enable LLM chat with your data - no preparation is needed.
Here's a quick demo showing natural language queries:
https://github.com/emmakodes/psqlomni/assets/34986076/0c58f4fd-c359-47c2-8e3c-4b068545e522
Installation
You will need:
- credentials for your database
- an OpenAI API Key from your OpenAI account.
then
pip install psqlomni
or download the source.
Run the CLI with:
psqlomni
or use python -m psqlomni
to run from source.
What can it do?
The Open AI model understands most Postgres syntax, so it can generate both generic SQL commands as well as very Postgres-specific ones like querying system settings. It can answer questions based on the databases' schema as well as on the databases' content (like describing a specific table).
The LLM is also good at analyzing tables, understanding what they are likely used for, and inferring relationships between tables. It is good at writing JOINs between tables without explicit instruction.
It can write queries to group and summarize results.
It can recover from errors by running a generated query, catching the traceback and regenerating it correctly.
It will save tokens by only retrieving the schema from relevant tables.
It also maintains a history of the chat, so you can easily ask follow up questions.
Configuration
You can configure the database connection either using psql
style command line arguments
or the env vars DBHOST
, DBNAME
, DBUSER
, DBPASSWORD
, DBPORT
.
Else when you first run the program it will prompt you for the connection credentials as well as your OpenAI API key.
After first setup all the configuration information is stored in ~/.psqlomni
. Delete that
file if you want to start over.
You can specify the number of sample rows that will be appended to each table description. This can increase performance as demonstrated in the paper Rajkumar et al, 2022 (https://arxiv.org/abs/2204.00498). Follows best practices as specified in: Rajkumar et al, 2022 (https://arxiv.org/abs/2204.00498)
How it works
psqlomni
uses Langchain and the OpenAI model to create an agent to work with your database.
When requested the LLM automatically generates the right SQL, ask if to execute the query, if yes(or y), it executes the query. The query results are then returned. If an error is returned, it rewrites the query, check the query, ask for confirmation to execute query and then try again.
Command Reference
There are a few system commands supported for meta operations:
help
- show system commands
connection
- show the current db connection details, and the active LLM model
exit
or ctrl-c to exit
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file psqlomni-0.1.1.tar.gz
.
File metadata
- Download URL: psqlomni-0.1.1.tar.gz
- Upload date:
- Size: 7.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.0 CPython/3.10.12 Linux/5.10.16.3-microsoft-standard-WSL2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5c115c91304c7885ce697c54bc651faa95f69e9a6ecc88fed2d24bf08ae983d7 |
|
MD5 | 0af92c83e2e130a8d5a627a4e29cf9da |
|
BLAKE2b-256 | 15d3b3cbb238dc8696323762481e637241670e2f974870c92a6379444cbdcfc3 |
File details
Details for the file psqlomni-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: psqlomni-0.1.1-py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.0 CPython/3.10.12 Linux/5.10.16.3-microsoft-standard-WSL2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8871ea8e415810f88db51e9dbf9aa7b5a9dbe07250605456845babc50a21c9bf |
|
MD5 | 6d1a98da7755d33aaede96e041c4e81a |
|
BLAKE2b-256 | fdfa1c7cab67762bd04960b5c2439faebb554d9b36f659628c872701b08bae95 |