Utility to generate ChatGPT prompts for SQL writing, offering table structure snapshots and sample row data from Postgres and sqlite databases.
Project description
ChatGPT Prompt for SQL Writing
Generate a prompt for writing SQL queries with LLMs like ChatGPT. Drop your database URL and table name into the script and it will generate a prompt for you to copy and paste into your favorite LLM.
What this does
- Snapshot of Table Structure: Understand the columns, types, and organization of your table at a glance.
- Sample Rows: Includes INSERT statements to describe the data in your table.
Usage
Install the package:
pip install llm-sql-prompt
Here's how to use it:
Usage: llm-sql-prompt [OPTIONS] DATABASE_URL [TABLE_NAME]
Options:
--help Show this message and exit.
Generate a prompt from a postgres database:
llm-sql-prompt postgresql://postgres:postgres@localhost:5555/database_name table_name | pbcopy
llm-sql-prompt $DATABASE_URL
Tunneling to a remote port
If you find yourself wanting to tunnel into a remote box and work with a production database, here's some helpful commands so you don't need to remember the weird SSH tunneling syntax:
function find_random_open_port() {
local start_port=${1:-1024}
local max_attempts=100
local attempt=0
local port=$start_port
while (( attempt < max_attempts )); do
if ! nc -z localhost $port 2>/dev/null; then
echo $port
return
fi
port=$((port + 1))
attempt=$((attempt + 1))
done
echo "No open port found after $max_attempts attempts, starting from $start_port." > /dev/stderr
return 1
}
function ssh-tunnel() {
if [ $# -lt 2 ]; then
echo "Usage: ssh-tunnel remote_host remote_port [local_port]"
echo "This function sets up SSH port forwarding."
return 1
fi
local remote_host=$1
local remote_port=$2
local local_port=${3:-$(find-random-open-port $remote_port)}
if [[ -z $local_port ]]; then
echo "Failed to find an open local port."
return 1
fi
echo "Forwarding local port $local_port to remote port $remote_port on $remote_host..."
set -x
ssh $remote_host -L ${local_port}:localhost:${remote_port}
}
TODO
Super basic script, needs a lot of work
- pg support
- one entrypoint
- use DB comments on columns + tables
- multiple tables
- prompt tweaking
- understand prompt size limits and sample records until one fits
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
Built Distribution
File details
Details for the file llm_sql_prompt-0.5.0.tar.gz
.
File metadata
- Download URL: llm_sql_prompt-0.5.0.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.9 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5ee9199b65b50f26a615535d763ab5861716caf783b53e2a6740a679f9452310 |
|
MD5 | e017f2a0e1425bdd00bec18801d50548 |
|
BLAKE2b-256 | 4872e7bb522acd890fdc53a578e9580427ebdde8e8d9d85451fe823d35b7af0c |
File details
Details for the file llm_sql_prompt-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: llm_sql_prompt-0.5.0-py3-none-any.whl
- Upload date:
- Size: 6.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.9 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c23728db7c385b0c4e80455b873478b3a4295a71c8a389331b32a5a26e422434 |
|
MD5 | 3eeb40fc9ae1d6c9c288fe4bbac5a00b |
|
BLAKE2b-256 | dd67849998f7eaaf5249bf8021ff5d250c698b284db55659dbdb8be6f6db7fac |