aimm-mcp
This MCP server manages AI data model projects locally, capturing SQL metadata and semantic context as JSON files. It exposes tools for project setup, schema analysis, and live database interaction via ODBC.
Project Management: Initialize new projects, manage project folders, list available projects, and set the active project. Configure project-level settings (description, SQL dialect, default connection, modeling paradigm, tags).
Context Retrieval: Read the full active project's data model context (connections, tables, columns, keys, relationships) in XML, Markdown, or raw JSON formats.
Connection Management: Create or update ODBC connection descriptors (Trino, SQL Server, Databricks) and list available system DSNs.
Live Schema Interaction: Browse live databases to discover schemas, tables, and columns; refresh column metadata from
information_schemawhile preserving user-defined semantic edits.Table & Relationship Definition: Update table properties, define primary keys, add foreign key relationships, and specify upstream data lineage.
Semantic Enrichment: Define table grain, document data pitfalls, classify columns (PII/PHI), manage glossary terms, and define measures/KPIs with formulas.
Join Discovery: Scan local
.sqlfiles to automatically extract and persist JOIN clauses using sqlglot.Schema Drift Detection: Diff authored column definitions against the current live database schema to identify discrepancies.
Diagnostics: Tail ODBC query logs for debugging and auditing.
Captures SQL data-model metadata from Databricks via ODBC, exposing table schemas, relationships, and lineage information.
Captures SQL data-model metadata from Trino via ODBC, exposing table schemas, relationships, and lineage information.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@aimm-mcpread the project context"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
aimm-mcp
Local Model Context Protocol server for the AI Model Manager.
Captures SQL data-model metadata as one JSON file per project
(<slug>.aimm.json) and exposes it to Claude Code (or any MCP
client) over stdio.
Fork of the AIMM VS Code extension,
rebuilt in Python with no UI: just tools the agent calls. Both the
VS Code extension and this server read/write the same project-file
format — share a project by committing one .aimm.json to your
repo.
Why this exists
The VS Code extension lives inside an editor. This fork lets you
skip the editor entirely — install once with claude mcp add, and
any Claude session on the machine sees the same models.
Install
One line. Claude Code spawns the server via uvx (uv's npx) — no
prior install, no setup.
claude mcp add aimm --scope user -- uvx aimm-mcpFirst connection downloads the package (a few seconds). Subsequent connections are cache-served.
For testing from a local checkout before PyPI, see
LOCAL_INSTALL.md.
Where state lives
Two concepts: machine-local sidecars (always at ~/Documents/AIMM/)
and project files (anywhere you point them, default the same folder).
~/Documents/AIMM/ machine-local, never moves
├── state.json which folder + which active project
├── discovered_joins.json scan output (not project state)
└── diagnostics.log ODBC query append-log
<projects_folder>/ defaults to ~/Documents/AIMM/
├── customer_warehouse.aimm.json one project
├── reporting_model.aimm.json another project
└── …A team checks <projects_folder> into a git repo. The agent runs
aimm_set_projects_folder to point at the local clone, then
aimm_list_projects + aimm_set_active_project to pick one. The
"active project" pointer survives across Claude Code sessions.
No derived snapshots on disk. Renderings (XML / markdown / raw JSON)
happen in-memory when aimm_read_project_context is called.
Engines
Three engines via ODBC: trino, sql_server, databricks.
Connection descriptors carry a DSN name (system DSN registered at
the OS level) plus the catalog / database qualifier.
Tools
Session / context
The agent must select an active project before any project-touching tool runs — these tools handle that bootstrap.
aimm_set_projects_folder— point the server at a folder of.aimm.jsonfiles (defaults to~/Documents/AIMM/). Use to switch to a team repo of shared projects. Clears the active pointer.aimm_list_projects— enumerate.aimm.jsonfiles in the current folder with their internal project name +updated_at.aimm_set_active_project— pick one as active. Subsequent tool calls read and write that file.aimm_show_active_project— report the current pointer state (folder + active file + on-disk status).
Project + context
aimm_init_project— create a new<slug>.aimm.json(slug derived fromname) in the current folder, set it as active.aimm_read_project_context— return the entire active project. Formats:xml(default),markdown,json(raw bytes of the active file).
Connections + live catalog
aimm_upsert_connection— create / update a connection descriptor. Validates Trino catalog requirement.aimm_list_system_dsns— pyodbc.dataSources() wrapper for discovery before upsert.aimm_browse_connection— drill into schemas / tables / columns on a live connection. Optional case-insensitive search filter.aimm_refresh_columns— re-fetch column shapes from information_schema and merge back into the active project (preserves user-edited PK / FK / description flags).
Table mutations
aimm_update_table— patch any non-identity field on a tracked table. Creates on first patch.aimm_set_primary_key— atomically set primary_keys + flip is_primary_key on matching columns.aimm_add_relationship— append an FK edge (idempotent on duplicates, composite keys supported).aimm_add_upstream— append a lineage edge.
Semantic context (the "what it means" layer)
The structural fields above tell the agent what's there. These
tell it what those things mean — captured once, surfaced on
every subsequent aimm_read_project_context call.
aimm_set_table_grain— one-line "what is a row?" per table.aimm_add_pitfall— append-with-dedupe to a table's "don't do this" list.aimm_set_column_classification— flag a column as pii / phi / restricted / internal / public.aimm_add_glossary_term— upsert a domain-vocabulary entry.aimm_add_measure— upsert a KPI / metric with definition + formula.aimm_update_project_config— patch the project header (description, conventions, dialect, default_connection, modeling_paradigm, tags).
Folder scan for joins
aimm_scan_folder_for_joins— walk a local folder of.sqlfiles, extract JOIN clauses via sqlglot (multi-dialect fallback: tsql → spark → none), persist canonical edges to~/Documents/AIMM/discovered_joins.json. Works without an active project.
Diagnostics
aimm_show_diagnostics_log— tail ofdiagnostics.logwhere every ODBC query is recorded.
Pending changes
aimm_get_pending_changes— per-tracked-table diff between authored columns and the liveinformation_schemashape.
Why ODBC?
Every warehouse this targets exposes an ODBC driver. We never run
user SQL — only information_schema reads for column / table /
schema metadata. Drivers stay read-only at the credential level.
Development
uv sync --dev
uv run python -m aimm_mcp # starts the MCP stdio server
uv run pytest -q # testsLicense
MIT.
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/DylanCodyBrown/aimm-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server