PostgreSQL MCP Server

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.

Category
Visit Server

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

MCP Demo MCP Demo MCP Demo MCP Demo MCP Demo MCP Demo

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

  1. Get server info:
    • Resource URI: postgres://info
    • Returns: Server information and available operations

Using Tools

  1. List all tables:

    Tool: list_tables
    Returns: {"tables": [...], "count": 4}
    
  2. Get table schema:

    {
      "table_name": "users"
    }
    Returns: {"table_name": "users", "columns": [...], "column_count": 5}
    
  3. Execute a query:

    {
      "query": "SELECT * FROM users LIMIT 10"
    }
    

    Returns: JSON with rows, row_count, and columns

  4. Get table statistics:

    {
      "table_name": "users"
    }
    

    Returns: JSON with row_count, total_size, table_size, and indexes_size

Using Prompts

  1. analyze_table:

    • Generates a comprehensive analysis workflow for a specific table
    • Parameter: table_name
  2. find_relationships:

    • Generates a prompt to analyze and document table relationships
  3. data_quality_check:

    • Generates a prompt for comprehensive data quality analysis

Security

  • Read-only queries: The execute_query tool 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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured