MCP Migration Advisor
Database migration risk analysis for Flyway and Liquibase. Detects dangerous schema changes — lock risks, data loss, destructive operations — before they hit production.
MCP Migration Advisor
MCP server for database migration risk analysis. Detects dangerous schema changes before they hit production.
Why This Tool?
Database migration failures cause outages. This tool analyzes your Flyway and Liquibase migrations before they run — detecting destructive operations, lock risks, and data loss patterns.
Unlike MigrationPilot (PG-only, raw SQL analysis), this tool parses Liquibase XML and YAML changelogs natively — extracting changeSets, detecting conflicts between changeSet IDs, and validating rollback completeness. It works across database types, not just PostgreSQL.
Features
- Lock Risk Analysis: Detects DDL operations that acquire heavy table locks (ACCESS EXCLUSIVE, SHARE locks)
- Data Loss Detection: Finds column drops, type changes that truncate, TRUNCATE/DELETE without WHERE
- Risk Scoring: Calculates 0-100 risk score based on severity of detected issues
- Flyway Support: Parses V__.sql and R__.sql migration filenames
- Liquibase Support: Parses XML and YAML changelogs with changeSet extraction
- Conflict Detection: Identifies duplicate changeSet IDs and ordering issues
- Rollback Validation: Checks rollback completeness for each changeSet
- Actionable Recommendations: Every risk includes a specific safe alternative
Pro Tier
Generate exportable diagnostic reports (HTML + PDF) with a Pro license key.
- Full JVM thread dump analysis report with actionable recommendations
- PDF export for sharing with your team
- Priority support
$9.00/month — Get Pro License
Pro license key activates the generate_report MCP tool in mcp-jvm-diagnostics.
Installation
npx mcp-migration-advisor
Or install globally:
npm install -g mcp-migration-advisor
Claude Desktop Configuration
Add to ~/.claude/claude_desktop_config.json:
{
"mcpServers": {
"migration-advisor": {
"command": "npx",
"args": ["-y", "mcp-migration-advisor"]
}
}
}
Quick Demo
Try these prompts in Claude:
- "Analyze this migration for risks: ALTER TABLE users DROP COLUMN email;" — Returns risk score (0-100), lock risks, data loss warnings, and safe alternatives
- "Generate a rollback for this migration: CREATE TABLE orders (...); CREATE INDEX idx_orders_user ON orders(user_id);" — Produces reverse DDL in correct order
- "Score this Liquibase changelog: [paste XML]" — Parses changeSets and calculates overall risk
Tools
analyze_migration
Full analysis of a SQL migration file. Returns lock risks, data loss analysis, and recommendations.
Parameters:
filename— Migration filename (e.g.,V2__add_user_email.sql)sql— The SQL content
analyze_liquibase
Full analysis of a Liquibase XML changelog. Parses changeSets and applies the same lock risk and data loss analysis.
Parameters:
xml— The Liquibase XML changelog content
analyze_liquibase_yaml
Full analysis of a Liquibase YAML changelog. Parses changeSets from YAML format and applies the same lock risk and data loss analysis. Supports all standard change types: createTable, dropTable, addColumn, dropColumn, modifyDataType, createIndex, renameTable, renameColumn, and more.
Parameters:
yaml— The Liquibase YAML changelog content
score_risk
Quick risk score (0-100) with verdict (LOW/MODERATE/HIGH RISK).
Parameters:
filename— Migration filenamesql— The SQL content
generate_rollback
Generate reverse DDL to undo a SQL migration. Produces rollback SQL with warnings for irreversible operations.
Parameters:
filename— Migration filenamesql— The SQL content
Reverses automatically:
- CREATE TABLE → DROP TABLE
- ADD COLUMN → ALTER TABLE ... DROP COLUMN
- CREATE INDEX → DROP INDEX (preserves CONCURRENTLY)
- ADD CONSTRAINT → DROP CONSTRAINT
- SET NOT NULL → DROP NOT NULL
- RENAME → reverse RENAME
Warns on irreversible:
- DROP TABLE, DROP COLUMN (data loss)
- Column type changes (original type unknown)
- DROP INDEX, DROP CONSTRAINT (original definition unknown)
Includes Flyway schema_history cleanup statement.
detect_conflicts
Detect conflicts between two SQL migration files. Identifies same-table modifications, same-column changes, lock contention risks, and drop dependencies that could cause failures if applied concurrently or in the wrong order.
Parameters:
filename_a— First migration filename (e.g.,V3__add_email.sql)sql_a— SQL content of the first migrationfilename_b— Second migration filename (e.g.,V4__modify_users.sql)sql_b— SQL content of the second migration
Detects:
- Same column conflicts (CRITICAL) — both migrations modify the same column on the same table
- Drop dependencies (CRITICAL) — one migration drops a table the other modifies, causing order-dependent failures
- Lock contention (WARNING) — both migrations require exclusive locks on the same table, risking lock wait timeouts
Returns a conflict report with severity levels, affected tables/columns, and whether the migrations can safely run concurrently.
What It Detects
| Pattern | Severity | Why It's Dangerous |
|---|---|---|
| NOT NULL without DEFAULT | CRITICAL | Full table rewrite with ACCESS EXCLUSIVE lock |
| Column type change | CRITICAL | Table rewrite, data truncation risk |
| CREATE INDEX (not CONCURRENTLY) | HIGH | SHARE lock blocks all writes |
| DROP TABLE CASCADE | CRITICAL | Drops all dependent objects |
| DROP COLUMN | HIGH | Irreversible data loss |
| SET NOT NULL | HIGH | Full table scan with lock |
| FOREIGN KEY constraint | MEDIUM | Locks both tables for validation |
| TRUNCATE / DELETE without WHERE | CERTAIN data loss | All rows permanently deleted |
Limitations & Known Issues
- Static analysis only: Analyzes SQL text without database connectivity. Cannot check actual table sizes, row counts, or existing schema to calibrate risk.
- PostgreSQL-focused: Lock risk recommendations are primarily for PostgreSQL. MySQL and SQLite lock behaviors differ and may not be fully covered.
- Complex DDL: Stored procedures, triggers, and dynamic SQL within migrations are classified as "OTHER" and receive generic risk assessment.
- Liquibase support: Handles standard XML and YAML changesets. JSON Liquibase format and custom change types are not supported.
- Rollback limitations: Auto-generated rollbacks cannot reverse DROP TABLE, DROP COLUMN, or type changes (data is lost). These produce warnings instead of rollback SQL.
- Multi-statement transactions: The parser splits on semicolons. Statements containing semicolons inside strings or dollar-quoted blocks may be split incorrectly.
- No execution: The advisor analyzes but never executes migrations. All recommendations are advisory.
- Database-specific DDL: Parser targets PostgreSQL/MySQL DDL syntax. Oracle PL/SQL or SQL Server T-SQL may not be fully recognized.
Part of the MCP Java Backend Suite
- mcp-db-analyzer — PostgreSQL/MySQL/SQLite schema analysis
- mcp-spring-boot-actuator — Spring Boot health, metrics, and bean analysis
- mcp-jvm-diagnostics — Thread dump and GC log analysis
- mcp-redis-diagnostics — Redis memory, slowlog, and client diagnostics
License
MIT
관련 서버
Gunsnation MCP
MCP server that gives assistants real-time access to the Gunsnation firearms catalog
ChatQL MCP Server
Query SQL Server databases using natural language with OpenAI GPT models.
Snapchat Ads by CData
A read-only MCP server for querying live Snapchat Ads data using the CData JDBC Driver.
Epicor Kinetic MCP Server by CData
A read-only MCP server by CData that enables LLMs to query live data from Epicor Kinetic.
Snowflake
Interact with Snowflake databases to query and manage data.
MySQL Server
A server for performing MySQL database operations.
lorg-mcp-server
Intelligence archive for AI agents. Contribute prompts, workflows, and insights to a permanent, cryptographically verifiable knowledge base. Agents earn public trust scores based on adoption and peer validation.
AudioAlpha
AudioAlpha turns 100+ daily finance and crypto podcasts into structured intelligence — α-sentiment scores, narrative signals, asset mentions, transcripts, and market snapshots with 40+ custom metrics. Built for AI-driven research and trading workflows.
Odoo Accounting MCP Server
Integrates with Odoo Accounting via XML-RPC, allowing AI tools to query and analyze account journal entries for auditing purposes.
FXMacroData
Real-time forex macroeconomic API for all major currency pairs sourced from central bank announcements.