Skip to main content

PostgreSQL MCP server for schema inspection, data exploration, and query execution.

Project description

pglens

A PostgreSQL MCP server with tools for schema inspection, data exploration, query execution, and database health monitoring.

Motivation

Most Postgres MCP servers expose query and list_tables, and that's about it. Agents end up guessing column names, enum values, and join paths, which leads to multiple failed attempts before landing on working SQL.

pglens adds the tools that close those gaps: checking what values actually exist in a column, discovering foreign-key relationships, previewing sample data, and validating query plans. The idea is straightforward: let the agent look before it leaps.

Tools

Schema and discovery

Tool What it does
list_tables Tables with row counts and descriptions
list_views Views with their SQL definitions
list_extensions Installed extensions and versions
describe_table Columns, types, PKs, FKs, indexes, check constraints
find_related_tables FK relationships in both directions
list_functions Stored functions/procedures with source code
list_triggers Triggers on a table with definitions and status
list_policies Row-level security policies on a table

Data exploration

Tool What it does
sample_rows Random rows from a table
column_values Distinct values with frequency counts
search_data Case-insensitive search across text columns
search_columns Find columns by name across all tables
search_enum_values Enum types and their allowed values

Query execution

Tool What it does
explain_query Query plan without execution
query Read-only SQL, capped at 500 rows

Performance and health

Tool What it does
table_stats Index hit rates, dead tuples, vacuum timestamps
table_sizes Disk usage per table, ranked by size
unused_indexes Indexes that are never scanned
bloat_stats Dead tuples, vacuum status, wraparound risk
active_queries Currently running sessions and their queries
blocking_locks Lock wait chains (who blocks whom)
sequence_health Sequences approaching exhaustion
matview_status Materialized view freshness and refresh eligibility

Safety before DDL

Tool What it does
object_dependencies What depends on a given object (views, functions, constraints)

There is also a query_guide prompt that describes a reasonable workflow for using these tools together.

A note on column_values

Agents frequently write WHERE status = 'active' when the actual value is 'Active' or 'enabled'. column_values returns the real distinct values in a column with counts, so the agent can pick the right one instead of guessing.

Installation

pip install pglens

Or with uv:

uv pip install pglens

Usage

pglens reads standard PostgreSQL environment variables. No config files, no flags.

export PGHOST=localhost
export PGUSER=myuser
export PGPASSWORD=mypassword
export PGDATABASE=mydb

pglens

The server uses stdio transport.

Claude Desktop

{
  "mcpServers": {
    "pglens": {
      "command": "pglens",
      "env": {
        "PGHOST": "localhost",
        "PGPORT": "5432",
        "PGUSER": "myuser",
        "PGPASSWORD": "mypassword",
        "PGDATABASE": "mydb"
      }
    }
  }
}

Claude Code

{
  "mcpServers": {
    "pglens": {
      "command": "pglens",
      "env": {
        "PGHOST": "localhost",
        "PGDATABASE": "mydb"
      }
    }
  }
}

Zed

{
  "context_servers": {
    "pglens": {
      "command": {
        "path": "pglens",
        "args": []
      }
    }
  }
}

Architecture

mcp_adapter.py  (MCP tool definitions, lifespan)
    |
asyncpg_adapter.py  (SQL queries, asyncpg pool)
    |
PostgreSQL

AsyncpgDatabase holds the asyncpg pool and all query methods. The MCP layer is a thin wrapper that delegates to it. All queries use pure pg_catalog introspection — no PostgreSQL extensions required.

Adding a tool

  1. Add a method to AsyncpgDatabase in adapters/asyncpg_adapter.py
  2. Add a @mcp.tool() function in adapters/mcp_adapter.py

Safety

  • All user-influenced queries run inside readonly=True transactions
  • Table and column identifiers are escaped via PostgreSQL's quote_ident()
  • No DDL tools are exposed

Requirements

  • Python 3.11+
  • PostgreSQL

License

MIT

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

pglens-0.1.0.tar.gz (69.9 kB view details)

Uploaded Source

Built Distribution

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

pglens-0.1.0-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

Details for the file pglens-0.1.0.tar.gz.

File metadata

  • Download URL: pglens-0.1.0.tar.gz
  • Upload date:
  • Size: 69.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pglens-0.1.0.tar.gz
Algorithm Hash digest
SHA256 bd85b6840d3bae48a99d7abc48605b26ba7c1983f4210b0608fc9350ada70c74
MD5 adc201eb7911482cc1aba72c48c7ef33
BLAKE2b-256 1829507ef759bbc7930280ae35635d55e86107dcbfc8b56cee7b200184d11981

See more details on using hashes here.

Provenance

The following attestation bundles were made for pglens-0.1.0.tar.gz:

Publisher: release.yml on janbjorge/pglens

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pglens-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: pglens-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 14.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pglens-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aaed5250e3ef0af341956b21e9d4b21f3c2520d168c5b007201d530aa598454e
MD5 3590746ff85c4087eb917ffe5f4a4250
BLAKE2b-256 e67a30b8b6eb233d881ea345c045ad9f950b0b878b3b29bd0d3c56ae2f711c00

See more details on using hashes here.

Provenance

The following attestation bundles were made for pglens-0.1.0-py3-none-any.whl:

Publisher: release.yml on janbjorge/pglens

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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