Go MCP Postgres
A standalone MCP server for interacting with PostgreSQL databases. It supports CRUD operations, a read-only mode, and query plan checking.
go-mcp-postgres
Overview
Copy code from https://github.com/Zhwt/go-mcp-mysql/ and with AI help, I change db from mysql to postgres.
Zero burden, ready-to-use Model Context Protocol (MCP) server for interacting with Postgres and automation. No Node.js or Python environment needed. This server provides tools to do CRUD operations on MySQL databases and tables, and a read-only mode to prevent surprise write operations. You can also make the MCP server check the query plan by using a EXPLAIN statement before executing the query by adding a --with-explain-check flag.
Please note that this is a work in progress and may not yet be ready for production use.
Installation
-
Get the latest release and put it in your
$PATHor somewhere you can easily access. -
Or if you have Go installed, you can build it from source:
go install -v github.com/guoling2008/go-mcp-postgres@latest
Usage
Method A: Using Command Line Arguments for stdio mode
{
"mcpServers": {
"postgres": {
"command": "go-mcp-postgres",
"args": [
"--dsn",
"postgresql://user:pass@host:port/db"
]
}
}
}
Note: For those who put the binary outside of your $PATH, you need to replace go-mcp-postgres with the full path to the binary: e.g.: if you put the binary in the Downloads folder, you may use the following path:
{
"mcpServers": {
"postgres": {
"command": "C:\\Users\\<username>\\Downloads\\go-mcp-postgres.exe",
"args": [
...
]
}
}
}
Method B: Using Command Line Arguments for sse mode
./go-mcp-postgres --t sse --ip x.x.x.x --port nnnn --dsn postgresql://user:pass@host:port/db --lang en
Optional Flags
--lang: Set language option (en/zh-CN), defaults to system language- Add a
--read-onlyflag to enable read-only mode. In this mode, only tools beginning withlist,read_anddesc_are available. Make sure to refresh/restart the MCP server after adding this flag. - By default, CRUD queries will be first executed with a
EXPLAIN ?statement to check whether the generated query plan matches the expected pattern. Add a--with-explain-checkflag to disable this behavior.
Tools
Multi-language support: All tool descriptions will automatically localize based on lang parameter
If you want to add your own language support, please refer to the [locales](for i18n) folder. The new locales/xxx/active-xx.toml file should be created if you want to use it in command line.
Schema Tools
-
list_database- ${mcp.tool.list_database.desc}
- Parameters: None
- Returns: A list of matching database names.
-
list_table- ${mcp.tool.list_table.desc}
- Parameters:
name: If provided, list tables with the specified name, Otherwise, list all tables.
- Returns: A list of matching table names.
-
create_table- ${mcp.tool.create_table.desc}
- Parameters:
query: The SQL query to create the table.
- Returns: x rows affected.
-
alter_table- Alter an existing table in the Postgres server. The LLM is informed not to drop an existing table or column.
- Parameters:
query: The SQL query to alter the table.
- Returns: x rows affected.
-
desc_table- Describe the structure of a table.
- Parameters:
name: The name of the table to describe.
- Returns: The structure of the table.
Data Tools
-
read_query- Execute a read-only SQL query.
- Parameters:
query: The SQL query to execute.
- Returns: The result of the query.
-
write_query- Execute a write SQL query.
- Parameters:
query: The SQL query to execute.
- Returns: x rows affected, last insert id: <last_insert_id>.
-
update_query- Execute an update SQL query.
- Parameters:
query: The SQL query to execute.
- Returns: x rows affected.
-
delete_query- Execute a delete SQL query.
- Parameters:
query: The SQL query to execute.
- Returns: x rows affected.
-
count_query- Query the number of rows in a certain table..
- Parameters:
name: The name of the table to count.
- Returns: The row number of the table.
Big thanks to https://github.com/Zhwt/go-mcp-mysql/ again.
License
MIT
İlgili Sunucular
dbt
Official MCP server for dbt (data build tool) providing integration with dbt Core/Cloud CLI, project metadata discovery, model information, and semantic layer querying capabilities.
FoodData Central
Access the USDA's FoodData Central database for comprehensive food and nutrient information.
MCP BigQuery Server
Securely access BigQuery datasets with intelligent caching, schema tracking, and query analytics via Supabase integration.
Video Metadata MCP Server
Manages video metadata, including game information, teams, scores, and other sports-related data.
Formula One MCP Server
Access Formula One data and statistics, including race calendars, session results, driver data, lap times, telemetry, and championship standings.
Google Directory by CData
A read-only MCP server for querying live Google Directory data using the CData JDBC Driver.
Memory-Plus
a lightweight, local RAG memory store to record, retrieve, update, delete, and visualize persistent "memories" across sessions—perfect for developers working with multiple AI coders (like Windsurf, Cursor, or Copilot) or anyone who wants their AI to actually remember them.
CData Zoho Books
A read-only MCP server by CData for querying live data from Zoho Books. Requires an external CData JDBC Driver.
Datai MCP Server
Provides real-time wallet portfolio data, including DeFi, token, and NFT holdings, using the Datai API.
InterSystems IRIS
Interact with and automate InterSystems IRIS databases.