Cover image
Try Now
2025-03-18

3 years

Works with Finder

1

Github Watches

4

Github Forks

5

Github Stars

PostgreSQL MCP Server (Enhanced)

A Model Context Protocol server that provides both read and write access to PostgreSQL databases. This server enables LLMs to inspect database schemas, execute queries, modify data, and create/modify database schema objects.

Note: This is an enhanced version of the original PostgreSQL MCP server by Anthropic. The original server provides read-only access, while this enhanced version adds write capabilities and schema management.

Components

Tools

Data Query

  • query
    • Execute read-only SQL queries against the connected database
    • Input: sql (string): The SQL query to execute
    • All queries are executed within a READ ONLY transaction

Data Modification

  • execute

    • Execute a SQL statement that modifies data (INSERT, UPDATE, DELETE)
    • Input: sql (string): The SQL statement to execute
    • Executed within a transaction with proper COMMIT/ROLLBACK handling
  • insert

    • Insert a new record into a table
    • Input:
      • table (string): The table name
      • data (object): Key-value pairs where keys are column names and values are the data to insert
  • update

    • Update records in a table
    • Input:
      • table (string): The table name
      • data (object): Key-value pairs for the fields to update
      • where (string): The WHERE condition to identify records to update
  • delete

    • Delete records from a table
    • Input:
      • table (string): The table name
      • where (string): The WHERE condition to identify records to delete

Schema Management

  • createTable

    • Create a new table with specified columns and constraints
    • Input:
      • tableName (string): The table name
      • columns (array): Array of column definitions with name, type, and optional constraints
      • constraints (array): Optional array of table-level constraints
  • createFunction

    • Create a PostgreSQL function/procedure
    • Input:
      • name (string): Function name
      • parameters (string): Function parameters
      • returnType (string): Return type
      • language (string): Language (plpgsql, sql, etc.)
      • body (string): Function body
      • options (string): Optional additional function options
  • createTrigger

    • Create a trigger on a table
    • Input:
      • name (string): Trigger name
      • tableName (string): Table to apply trigger to
      • functionName (string): Function to call
      • when (string): BEFORE, AFTER, or INSTEAD OF
      • events (array): Array of events (INSERT, UPDATE, DELETE)
      • forEach (string): ROW or STATEMENT
      • condition (string): Optional WHEN condition
  • createIndex

    • Create an index on a table
    • Input:
      • tableName (string): Table name
      • indexName (string): Index name
      • columns (array): Columns to index
      • unique (boolean): Whether the index is unique
      • type (string): Optional index type (BTREE, HASH, GIN, GIST, etc.)
      • where (string): Optional condition
  • alterTable

    • Alter a table structure
    • Input:
      • tableName (string): Table name
      • operation (string): Operation (ADD COLUMN, DROP COLUMN, etc.)
      • details (string): Operation details

Resources

The server provides schema information for each table in the database:

  • Table Schemas (postgres://<host>/<table>/schema)
    • JSON schema information for each table
    • Includes column names and data types
    • Automatically discovered from database metadata

Usage with Claude Desktop

To use this server with the Claude Desktop app, add the following configuration to the "mcpServers" section of your claude_desktop_config.json:

Docker

  • when running docker on macos, use host.docker.internal if the server is running on the host network (eg localhost)
  • username/password can be added to the postgresql url with postgresql://user:password@host:port/db-name
  • add ?sslmode=no-verify if you need to bypass SSL certificate verification
{
  "mcpServers": {
    "postgres": {
      "command": "docker",
      "args": [
        "run", 
        "-i", 
        "--rm", 
        "mcp/postgres", 
        "postgresql://host.docker.internal:5432/mydb"]
    }
  }
}

NPX

{
  "mcpServers": {
    "postgres": {
      "command": "npx",
      "args": [
        "-y",
        "@modelcontextprotocol/server-postgres",
        "postgresql://localhost/mydb"
      ]
    }
  }
}

Replace /mydb with your database name.

Example Usage

Query Data

/query SELECT * FROM users LIMIT 5

Insert Data

/insert table="users", data={"name": "John Doe", "email": "john@example.com"}

Update Data

/update table="users", data={"status": "inactive"}, where="id='123'"

Create a Table

/createTable tableName="tasks", columns=[
  {"name": "id", "type": "SERIAL", "constraints": "PRIMARY KEY"}, 
  {"name": "title", "type": "VARCHAR(100)", "constraints": "NOT NULL"},
  {"name": "created_at", "type": "TIMESTAMP", "constraints": "DEFAULT CURRENT_TIMESTAMP"}
]

Create a Function and Trigger

/createFunction name="update_timestamp", parameters="", returnType="TRIGGER", language="plpgsql", body="BEGIN NEW.updated_at = NOW(); RETURN NEW; END;"

/createTrigger name="set_timestamp", tableName="tasks", functionName="update_timestamp", when="BEFORE", events=["UPDATE"], forEach="ROW"

Building

Docker:

docker build -t mcp/postgres -f Dockerfile . 

Security Considerations

  1. All data modification operations use transactions with proper COMMIT/ROLLBACK handling
  2. Each operation returns the SQL that was executed for transparency
  3. The server uses parameterized queries for insert/update operations to prevent SQL injection

License

This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.

相关推荐

  • NiKole Maxwell
  • I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Callycode Limited
  • A geek-themed horoscope generator blending Bitcoin prices, tech jargon, and astrological whimsy.

  • Alexandru Strujac
  • Efficient thumbnail creator for YouTube videos

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Beniyam Berhanu
  • Therapist adept at identifying core issues and offering practical advice with images.

  • Khalid kalib
  • Write professional emails

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • INFOLAB OPERATIONS 2
  • A medical specialist offering assistance grounded in clinical guidelines. Disclaimer: This is intended for research and is NOT safe for clinical use!

  • apappascs
  • 发现市场上最全面,最新的MCP服务器集合。该存储库充当集中式枢纽,提供了广泛的开源和专有MCP服务器目录,并提供功能,文档链接和贡献者。

  • ShrimpingIt
  • MCP系列GPIO Expander的基于Micropython I2C的操作,源自ADAFRUIT_MCP230XX

  • OffchainLabs
  • 进行以太坊的实施

  • huahuayu
  • 统一的API网关,用于将多个Etherscan样区块链Explorer API与对AI助手的模型上下文协议(MCP)支持。

  • deemkeen
  • 用电源组合控制您的MBOT2:MQTT+MCP+LLM

  • zhaoyunxing92
  • MCP(消息连接器协议)服务

  • pontusab
  • 光标与风浪冲浪社区,查找规则和MCP

    Reviews

    3 (1)
    Avatar
    user_3D3HSjIQ
    2025-04-15

    Library Docs MCP Server by vikramdse is an invaluable resource for managing documentation on MCP servers. The user interface is intuitive and the features are robust, making it easy to streamline operations and enhance productivity. Highly recommended for anyone looking to simplify their server documentation tasks. Check it out here: https://mcp.so/server/docs-mcp-server/vikramdse.