PostgreSQL MCP Server
Enables interaction with PostgreSQL databases through resources, tools, and prompts for data analysis, including listing tables, executing read-only queries, and generating analysis workflows.
README
<div align="center"> <img src="https://raw.githubusercontent.com/CyprianFusi/MCP-server-postgres/main/assets/binati_logo.png" alt="BINATI AI Logo" width="75"/><strong></strong>
PostgreSQL MCP Server
By BINATI AInalytics </div>
An MCP (Model Context Protocol) server that provides access to PostgreSQL databases through resources, tools, and prompts for data analysis.
Screenshoots

Features
Resources
- postgres://info - Server information and quick reference
Tools
- list_tables - List all tables in the database
- get_table_schema - Get detailed schema for a specific table
- execute_query - Execute read-only SQL queries (SELECT, WITH, SHOW)
- get_table_stats - Get statistics for a table (row count, size, indexes)
Prompts
- analyze_table - Generate a comprehensive analysis prompt for a specific table
- find_relationships - Analyze database to find relationships between tables
- data_quality_check - Perform comprehensive data quality check
Installation
This project uses uv for package management.
# Install dependencies
uv sync
Configuration
Create a .env file with your database credentials. You can either:
Option 1: Individual components (recommended)
DATABASE_HOST=localhost
DATABASE_USER=postgres
DATABASE_PASSWORD=your_password
DATABASE_PORT=5432
DATABASE_NAME=your_database
Option 2: Full connection URL
DATABASE_URL=postgresql://postgres:password@localhost:5432/mydb
Note: If you use the SQLAlchemy format postgresql+psycopg://, it will be automatically converted to the psycopg format postgresql://.
The server will automatically construct the connection URL from individual components if DATABASE_URL is not provided.
Usage
Development Mode
Test the server using the MCP Inspector:
uv run mcp dev main.py
This will launch the MCP Inspector in your browser where you can:
- Browse available resources
- Test tools with different parameters
- Try out prompts
Install to Claude Desktop
To use this server with Claude Desktop:
uv run mcp install main.py --name "PostgreSQL Server"
Direct Execution
Run the server directly:
uv run python main.py
Example Usage
Using Resources
- Get server info:
- Resource URI:
postgres://info - Returns: Server information and available operations
- Resource URI:
Using Tools
-
List all tables:
Tool: list_tables Returns: {"tables": [...], "count": 4} -
Get table schema:
{ "table_name": "users" } Returns: {"table_name": "users", "columns": [...], "column_count": 5} -
Execute a query:
{ "query": "SELECT * FROM users LIMIT 10" }Returns: JSON with rows, row_count, and columns
-
Get table statistics:
{ "table_name": "users" }Returns: JSON with row_count, total_size, table_size, and indexes_size
Using Prompts
-
analyze_table:
- Generates a comprehensive analysis workflow for a specific table
- Parameter:
table_name
-
find_relationships:
- Generates a prompt to analyze and document table relationships
-
data_quality_check:
- Generates a prompt for comprehensive data quality analysis
Security
- Read-only queries: The
execute_querytool only allows SELECT, WITH, and SHOW statements - SQL injection protection: All queries use parameterized statements where applicable
- Connection management: Database connections are managed through lifespan context
Development
Code Quality
The project follows strict development guidelines:
# Format code
uv run --frozen ruff format .
# Check linting
uv run --frozen ruff check .
# Fix linting issues
uv run --frozen ruff check . --fix
# Type checking
uv run --frozen pyright
Testing
# Run tests
uv run --frozen pytest
Architecture
The server uses:
- FastMCP: High-level MCP server framework
- psycopg: Async PostgreSQL adapter for Python
- Lifespan management: Database connection is established at server startup and closed at shutdown
- Type safety: Full type hints throughout the codebase
License
MIT
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.