Skip to main content

PostgreSQL MCP Server

Project description

PgSQL MCP Server

PyPI - Version PyPI - Python Version Maintainability

English | 简体中文

A powerful tool server based on the Model Context Protocol (MCP), enabling interaction with PostgreSQL databases via MCP calls.


🚀 Overview

This project is built on the FastMCP framework and leverages the SQLAlchemy and asyncpg libraries to deliver high-performance asynchronous database operations, ensuring efficiency and responsiveness when handling database requests.

✨ Key Features

  • Asynchronous & Efficient: Fully asynchronous implementation based on asyncio, utilizing asyncpg for a high-performance asynchronous PostgreSQL driver.
  • Transactional Safety: DDL, DML, and DCL operations are executed within transactions with error handling and rollback mechanisms.
  • Easy Deployment: Start the server with a simple command line interface.

📦 Installation

Ensure you have Python 3.10+ installed. Recommendation:

Using uv (Recommended)

uv tool install pgsql-mcp-server

Then run it:

pgsql-mcp-server --dsn "postgresql://user:password@localhost:5432/db"

Or run directly without installation:

uvx pgsql-mcp-server --dsn "postgresql://user:password@localhost:5432/db"

Using pip

pip install pgsql-mcp-server

🛠️ Available Tools

The server provides the following tools for database interaction:

  • get_schema_names: List all schemas in the database.
  • get_tables: List all tables in a specific schema (defaults to public).
  • get_columns: Get detailed column information for a specific table.
  • get_indexes: Get index details for a specific table.
  • get_foreign_keys: Get foreign key constraints for a specific table.
  • run_dql_query: Execute Data Query Language (DQL) statements like SELECT, SHOW, EXPLAIN.
  • run_dml_query: Execute Data Manipulation Language (DML) statements like INSERT, UPDATE, DELETE.
  • run_ddl_query: Execute Data Definition Language (DDL) statements like CREATE, ALTER, DROP.
  • run_dcl_query: Execute Data Control Language (DCL) statements like GRANT, REVOKE.

🔍 Preview and Debugging

You can use the official MCP Inspector tool to visually inspect the tools provided by this server, view their parameters and descriptions, and perform test calls directly.

npx @modelcontextprotocol/inspector uvx pgsql-mcp-server --dsn "postgresql://user:password@host:port/database"

This will start a local web service. Open the provided URL in your browser to begin debugging.

🧪 Testing

This project uses pytest for testing.

Run all tests

uv run pytest

Run unit tests only

uv run pytest tests/test_app.py

Run integration tests only

Integration tests require a local PostgreSQL instance. They default to localhost:5432/postgres.

uv run pytest tests/test_integration.py

🤝 Contributing

Contributions are welcome! If you have suggestions for improvements, feature requests, or find any bugs, please feel free to:

  1. Open an Issue to discuss.
  2. Fork the repository and create your feature branch (git checkout -b feature/AmazingFeature).
  3. Commit your changes (git commit -m 'Add some AmazingFeature').
  4. Push to the branch (git push origin feature/AmazingFeature).
  5. Open a Pull Request.

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

pgsql_mcp_server-1.4.6.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pgsql_mcp_server-1.4.6-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file pgsql_mcp_server-1.4.6.tar.gz.

File metadata

  • Download URL: pgsql_mcp_server-1.4.6.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for pgsql_mcp_server-1.4.6.tar.gz
Algorithm Hash digest
SHA256 dd18970678f9d005a0427311cea59f9240ff6db7430eb470c42610afa95882c9
MD5 b6636a17280e9d8f40a99c335af8b794
BLAKE2b-256 a32f6032ee678d0bbeb41c0477dbbaf8d83eaffe26829c318195f8bcc6893543

See more details on using hashes here.

File details

Details for the file pgsql_mcp_server-1.4.6-py3-none-any.whl.

File metadata

  • Download URL: pgsql_mcp_server-1.4.6-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for pgsql_mcp_server-1.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 0d9a86f830974d597dddc297e866b06ceb641a7d37cdeccc1d02a143c8a7a42d
MD5 2de7fd6569ba25ef41fec0417b68885a
BLAKE2b-256 3e24d36b90c01613597743a069c9be07ebd145c392f30e9c88abda93227b3f7e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page