pg-mcp
Enables natural language querying of PostgreSQL databases through the Model Context Protocol. It translates user questions into validated SQL, executes read-only queries safely, and returns results to MCP-compatible clients like Claude Desktop.
README
pg-mcp
Natural language PostgreSQL query service via MCP (Model Context Protocol). Uses OpenAI to translate natural language into SQL, validates and executes it safely, and returns results to any MCP-compatible client.
Features
- Natural language to SQL via OpenAI
- Auto-discovers database schema on startup (tables, views, columns, indexes, foreign keys, enums)
- Schema cache with optional disk persistence
- SQL safety validation (SELECT-only, dangerous function blocking, LIMIT enforcement)
- Read-only transaction execution with configurable timeout
- Result validation with automatic retry on empty results
- Supports multiple databases
Requirements
- Python 3.11+
- PostgreSQL
- OpenAI API key
Installation
pip install -e .
For development:
pip install -e ".[dev]"
Configuration
Copy .env.example to .env and fill in your values:
cp .env.example .env
| Variable | Required | Default | Description |
|---|---|---|---|
PG_MCP_DATABASES |
Yes | — | Comma-separated PostgreSQL connection strings |
PG_MCP_DEFAULT_DB |
No | First DSN | Default database for queries |
OPENAI_API_KEY |
Yes | — | OpenAI API key |
OPENAI_MODEL |
No | gpt-4o |
Model to use for SQL generation |
OPENAI_BASE_URL |
No | OpenAI default | Custom endpoint (Azure, proxy, etc.) |
PG_MCP_QUERY_TIMEOUT |
No | 30 |
Query timeout in seconds |
PG_MCP_MAX_ROWS |
No | 100 |
Max rows returned (1-1000) |
PG_MCP_SCHEMA_CACHE_PATH |
No | None | Path for persistent schema cache |
PG_MCP_LOG_LEVEL |
No | INFO |
DEBUG / INFO / WARNING / ERROR |
Multiple databases example:
PG_MCP_DATABASES=postgresql://user:pass@host1:5432/db1,postgresql://user:pass@host2:5432/db2
Usage with Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"pg-mcp": {
"command": "python3",
"args": ["-m", "pg_mcp.server"],
"env": {
"PG_MCP_DATABASES": "postgresql://user:pass@localhost:5432/mydb",
"OPENAI_API_KEY": "sk-...",
"PG_MCP_SCHEMA_CACHE_PATH": "~/.cache/pg-mcp/schema.json"
}
}
}
}
MCP Tools
query
Query a database using natural language.
{
"question": "What are the top 10 customers by sales last month?",
"database": "mydb",
"return_sql": false,
"max_rows": 100
}
return_sql: true— returns the generated SQL without executingreturn_sql: false(default) — executes and returns results
list_databases
List all accessible databases with summary info.
describe_database
Get detailed schema info for a database.
{
"database": "mydb",
"schema": "public",
"pattern": "user"
}
refresh_schema
Reload schema cache from the database.
{
"database": "mydb"
}
Omit database to refresh all databases.
Running Tests
python3 -m pytest tests/ -v
How It Works
User question
→ Schema context assembled from cache
→ OpenAI generates SQL
→ Safety validation (SELECT-only, no dangerous functions, LIMIT injection)
→ Execute in read-only transaction with timeout
→ Optional result validation on empty results
→ Return SQL or query results
Security
- Generated SQL is validated to be SELECT-only (including CTE checks)
- Dangerous PostgreSQL functions are blocked (
pg_sleep,lo_import, etc.) - All queries execute in read-only transactions
- Automatic LIMIT enforcement prevents large result sets
- Query timeout prevents long-running queries
- Connection passwords never appear in logs or API responses
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.