loading…
Search for a command to run...
loading…
Enables Claude Desktop to interact with PostgreSQL databases through natural language for schema exploration, data analysis, and query execution. Users can sear
Enables Claude Desktop to interact with PostgreSQL databases through natural language for schema exploration, data analysis, and query execution. Users can search schemas, describe tables, and perform read or write operations without needing to write manual SQL.
Connect Claude Desktop to your PostgreSQL database using the Model Context Protocol (MCP). Ask Claude questions in plain English and it will query your database, explore schemas, and analyze data — no SQL required.
| Category | Tools |
|---|---|
| 🗄️ Database Info | get_database_info, list_databases |
| 📂 Schema Exploration | list_schemas, list_tables, describe_table, search_schema, list_indexes |
| 🔍 Querying | execute_query, get_table_sample, get_table_stats, explain_query |
| ✏️ Write Operations | execute_write (disabled by default — opt-in via .env) |
| 📄 Resources | schema://overview, table://{schema}/{table} |
| 💬 Prompts | analyze_table, write_sql_query |
git clone https://github.com/sarotechhub/Claude-Desktop-to-PostgreSQL.git
cd Cluade-MCP-PostgreSQL
# Windows
python -m venv .venv
.venv\Scripts\activate
# macOS / Linux
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
# Copy the example env file
cp .env.example .env
Edit .env with your PostgreSQL credentials:
DB_HOST=localhost
DB_PORT=5432
DB_NAME=your_database_name
DB_USER=your_username
DB_PASSWORD=your_password
# Set to "true" to allow INSERT/UPDATE/DELETE
ALLOW_WRITE_OPERATIONS=false
All credentials live only in
.env— they are never put in the Claude Desktop config file.
python main.py
You should see:
🚀 Starting PostgreSQL MCP Server...
✅ Database connection pool ready.
Press Ctrl+C to stop.
Find your Claude Desktop config file:
| OS | Path |
|---|---|
| Windows | %APPDATA%\Claude\claude_desktop_config.json |
| macOS | ~/Library/Application Support/Claude/claude_desktop_config.json |
| Linux | ~/.config/Claude/claude_desktop_config.json |
Add the postgres block to the mcpServers section (update the path):
{
"mcpServers": {
"postgres": {
"command": "[PATH_TO_YOUR_VENV_PYTHON_EXE]",
"args": ["[PATH_TO_YOUR_PROJECT_ROOT]\\main.py"],
"cwd": "[PATH_TO_YOUR_PROJECT_ROOT]",
"env": {
"PYTHONPATH": "[PATH_TO_YOUR_PROJECT_ROOT]"
}
}
}
}
Note: No DB credentials go in this file. The server reads them automatically from your
.envfile usingpython-dotenv.
Restart Claude Desktop after saving the config.
Once connected, try asking Claude:
"List all tables in my database"
"Describe the structure of the users table"
"Show me 10 sample rows from the orders table"
"How many rows are in each table in the public schema?"
"Find all columns related to 'email' across all tables"
"What indexes exist on the products table?"
"Write a query to find the top 10 customers by total order value"
"Explain why this query might be slow: SELECT * FROM orders WHERE status = 'pending'"
| Tool | Description |
|---|---|
get_database_info |
PostgreSQL version, DB size, connection count, server info |
list_databases |
All databases on the server with sizes and encoding |
| Tool | Description |
|---|---|
list_schemas() |
All user-defined schemas in the connected database |
list_tables(schema) |
Tables in a schema with row counts and sizes |
describe_table(table, schema) |
Columns, types, nullable, defaults, PKs, FKs |
search_schema(keyword) |
Find tables/columns by keyword (case-insensitive) |
list_indexes(table, schema) |
Indexes on a table with type and columns |
| Tool | Description |
|---|---|
execute_query(sql, limit) |
Read-only SELECT (enforced via read-only transaction) |
get_table_sample(table, schema, limit) |
Sample rows from a table (max 100) |
get_table_stats(table, schema) |
Row counts, sizes, vacuum/analyze timestamps |
explain_query(sql) |
EXPLAIN execution plan (no data modification) |
| Tool | Description |
|---|---|
execute_write(sql, confirm) |
INSERT/UPDATE/DELETE — requires ALLOW_WRITE_OPERATIONS=true in .env AND confirm=True |
.env.env only — never in the Claude Desktop configreadonly=True transactions.env excluded from git — credentials never committedCluade-MCP-PostgreSQL/
├── main.py # 🚀 MCP server entry point (FastMCP + stdio)
├── database.py # 🔌 Async connection pool (asyncpg)
├── tools/
│ ├── __init__.py
│ ├── schema_tools.py # list_schemas, list_tables, describe_table, search_schema, list_indexes
│ ├── query_tools.py # execute_query, get_table_sample, get_table_stats, explain_query
│ ├── write_tools.py # execute_write (opt-in)
│ └── database_tools.py # get_database_info, list_databases
├── .env # ✅ Your credentials (NOT committed to git)
├── .env.example # Template for new users
├── .gitignore # Excludes .env, .venv, __pycache__
├── requirements.txt # mcp[cli], asyncpg, python-dotenv, pydantic, orjson
├── claude_desktop_config.json # Example Claude Desktop config snippet
└── README.md
All configuration is done via .env:
| Variable | Default | Description |
|---|---|---|
DB_HOST |
localhost |
PostgreSQL host |
DB_PORT |
5432 |
PostgreSQL port |
DB_NAME |
— | Database name |
DB_USER |
— | Database user |
DB_PASSWORD |
— | Database password |
DB_MIN_CONNECTIONS |
1 |
Min pool connections |
DB_MAX_CONNECTIONS |
10 |
Max pool connections |
ALLOW_WRITE_OPERATIONS |
false |
Enable INSERT/UPDATE/DELETE |
LOG_LEVEL |
INFO |
Logging level (DEBUG/INFO/WARNING) |
cwd path — it must point to the project folder.venv Python path is correct: .venv\Scripts\python.exe.env credentials match your PostgreSQL setuppsql -h localhost -U your_user -d your_dbpg_isreadymcp or asyncpg module not found.venv\Scripts\pip install -r requirements.txt
postgres server entrypython main.py manually and check stderr for import errorsMIT License — free to use, modify, and distribute.
Pull requests welcome! Please fork the repo, create a feature branch, and submit a PR with a clear description.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"postgresql-mcp-server-for-claude-desktop": {
"command": "npx",
"args": []
}
}
}Query your database in natural language
Read-only database access with schema inspection.
Interact with Redis key-value stores.
Database interaction and business intelligence capabilities.