MCP PostgreSQL 服务器是一个提供 PostgreSQL 数据库操作的模型上下文协议(MCP)服务器。它为 AI 模型提供了标准化接口,使其能够与 PostgreSQL 数据库进行交互。
MCP PostgreSQL 服务器可助力 AI 模型与 PostgreSQL 数据库进行交互,以下为你介绍它的安装、配置及使用方法。
你可以使用以下命令进行安装:
npm install mcp-postgres-server
或者直接运行:
npx mcp-postgres-server
服务器需要配置以下环境变量:
{
"mcpServers": {
"postgres": {
"type": "stdio",
"command": "npx",
"args": ["-y", "mcp-postgres-server"],
"env": {
"PG_HOST": "your_host",
"PG_PORT": "5432",
"PG_USER": "your_user",
"PG_PASSWORD": "your_password",
"PG_DATABASE": "your_database"
}
}
}
}
使用提供的凭证建立与 PostgreSQL 数据库的连接。
use_mcp_tool({
server_name: "postgres",
tool_name: "connect_db",
arguments: {
host: "localhost",
port: 5432,
user: "your_user",
password: "your_password",
database: "your_database"
}
});
执行 SELECT 查询,支持可选的预处理语句参数。支持 PostgreSQL 样式($1, $2)和 MySQL 样式 (?) 参数占位符。
use_mcp_tool({
server_name: "postgres",
tool_name: "query",
arguments: {
sql: "SELECT * FROM users WHERE id = $1",
params: [1]
}
});
执行 INSERT、UPDATE 或 DELETE 查询,支持可选的预处理语句参数。支持 PostgreSQL 样式($1, $2)和 MySQL 样式 (?) 参数占位符。
use_mcp_tool({
server_name: "postgres",
tool_name: "execute",
arguments: {
sql: "INSERT INTO users (name, email) VALUES ($1, $2)",
params: ["John Doe", "john@example.com"]
}
});
列出数据库中的所有架构。
use_mcp_tool({
server_name: "postgres",
tool_name: "list_schemas",
arguments: {}
});
列出数据库中的表。接受一个可选的架构参数(默认为 'public')。
// 列出 'public' 架构中的表(默认)
use_mcp_tool({
server_name: "postgres",
tool_name: "list_tables",
arguments: {}
});
// 列出特定架构中的表
use_mcp_tool({
server_name: "postgres",
tool_name: "list_tables",
arguments: {
schema: "my_schema"
}
});
获取特定表格的结构。接受一个可选的架构参数(默认为 'public')。
// 描述 'public' 架构中的表(默认)
use_mcp_tool({
server_name: "postgres",
tool_name: "describe_table",
arguments: {
table: "users"
}
});
// 描述特定架构中的表
use_mcp_tool({
server_name: "postgres",
tool_name: "describe_table",
arguments: {
table: "users",
schema: "my_schema"
}
});
``` (原文档此处许可证内容为空,故保留原样)