This agent uses the PostgreSQL MCP server to interact with PostgreSQL databases. It demonstrates how to:
- Connect to a PostgreSQL database using MCP (Model Context Protocol)
- Use
uvxto run the MCP server without manual installation - Pass database credentials securely via environment variables
- PostgreSQL Database: You need access to a PostgreSQL database with a connection string
- uvx: The agent uses
uvx(part of theuvpackage manager) to run the MCP server
Create a .env file in the mcp_postgres_agent directory:
POSTGRES_CONNECTION_STRING=postgresql://user:password@host:port/databaseExample connection string format:
postgresql://username:password@localhost:5432/mydb
postgresql://postgres.xyz:password@aws-region.pooler.supabase.com:5432/postgres
Start the ADK Web UI from the samples directory:
adk webThe agent will automatically:
- Load the connection string from the
.envfile - Use
uvxto run thepostgres-mcpserver with unrestricted access mode - Connect to your PostgreSQL database
Once the agent is running, try these queries:
- "What tables are in the database?"
- "Show me the schema for the users table"
- "Query the first 10 rows from the products table"
- "What indexes exist on the orders table?"
- "Create a new table called test_table with columns id and name"
The agent uses:
- Model: Gemini 2.0 Flash
- MCP Server:
postgres-mcp(viauvx) - Access Mode: Unrestricted (allows read/write operations). Warning: Using unrestricted mode in a production environment can pose significant security risks. It is recommended to use a more restrictive access mode or configure database user permissions appropriately for production use.
- Connection: StdioConnectionParams with 60-second timeout
- Environment Variable:
DATABASE_URI(mapped fromPOSTGRES_CONNECTION_STRING)
- Ensure your
POSTGRES_CONNECTION_STRINGis correctly formatted - Verify database credentials and network access
- Check that
uvis installed (pip install uvorbrew install uv)