Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Safe, zero-downtime database migration strategies — schema evolution, rollback planning, data migration, tooling, and anti-pattern avoidance for production systems. Use when planning schema changes, writing migrations, or reviewing migration safety.
Safe, zero-downtime database migration strategies — schema evolution, rollback planning, data migration, tooling, and anti-pattern avoidance for production systems. Use when planning schema changes, writing migrations, or reviewing migration safety.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Then review README.md for any prerequisites, environment setup, or post-install checks. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run.
StrategyRiskDowntimeBest ForAdditive-OnlyVery LowNoneAPIs with backward-compatibility guaranteesExpand-ContractLowNoneRenaming, restructuring, type changesParallel ChangeLowNoneHigh-risk changes on critical tablesLazy MigrationMediumNoneLarge tables where bulk migration is too slowBig BangHighYesDev/staging or small datasets only Default to Additive-Only. Escalate to Expand-Contract only when you must modify or remove existing structures.
Every production migration must avoid locking tables or breaking running application code. OperationPatternKey ConstraintAdd columnNullable firstNever add NOT NULL without default on large tablesRename columnExpand-contractAdd new → dual-write → backfill → switch reads → drop oldDrop columnDeprecate firstStop reading → stop writing → deploy → dropChange typeParallel columnAdd new type → dual-write + cast → switch → drop oldAdd indexConcurrentCREATE INDEX CONCURRENTLY — don't wrap in transactionSplit tableExtract + FKCreate new → backfill → add FK → update queries → drop old columnsChange constraintTwo-phaseAdd NOT VALID → VALIDATE CONSTRAINT separatelyAdd enum valueAppend onlyNever remove or rename existing values
ToolEcosystemStyleKey StrengthPrisma MigrateTypeScript/NodeDeclarative (schema diff)ORM integration, shadow DBKnexJavaScript/NodeImperative (up/down)Lightweight, flexibleDrizzle KitTypeScript/NodeDeclarative (schema diff)Type-safe, SQL-likeAlembicPythonImperative (upgrade/downgrade)Granular control, autogenerateDjango MigrationsPython/DjangoDeclarative (model diff)Auto-detectionFlywayJVM / CLISQL file versioningSimple, wide DB supportgolang-migrateGo / CLISQL (up/down files)Minimal, embeddableAtlasGo / CLIDeclarative (HCL/SQL diff)Schema-as-code, linting, CI Match the tool to your ORM and deployment pipeline. Prefer declarative for simple schemas, imperative for fine-grained data manipulation.
ApproachWhen to UseReversible (up + down)Schema-only changes, early-stage productsForward-only (corrective migration)Data-destructive changes, production at scaleHybridReversible for schema, forward-only for data
Soft-delete columns — rename with _deprecated suffix instead of dropping Snapshot tables — CREATE TABLE _backup_<table>_<date> AS SELECT * FROM <table> Point-in-time recovery — ensure WAL archiving covers migration windows Logical backups — pg_dump of affected tables before migration
1. Replicate primary → secondary (green) 2. Apply migration to green 3. Run validation suite against green 4. Switch traffic to green 5. Keep blue as rollback target (N hours) 6. Decommission blue after confidence window
StrategyBest ForInline backfillSmall tables (< 100K rows)Batched backfillMedium tables (100K–10M rows)Background jobLarge tables (10M+ rows)Lazy backfillWhen immediate consistency not required
DO $$ DECLARE batch_size INT := 1000; rows_updated INT; BEGIN LOOP UPDATE my_table SET new_col = compute_value(old_col) WHERE id IN ( SELECT id FROM my_table WHERE new_col IS NULL LIMIT batch_size FOR UPDATE SKIP LOCKED ); GET DIAGNOSTICS rows_updated = ROW_COUNT; EXIT WHEN rows_updated = 0; PERFORM pg_sleep(0.1); -- throttle to reduce lock pressure COMMIT; END LOOP; END $$;
For expand-contract and parallel change: Dual-write — application writes to both old and new columns/tables Backfill — fill new structure with historical data Verify — assert consistency (row counts, checksums) Cut over — switch reads to new, stop writing to old Cleanup — drop old structure after cool-down period
Never test against empty or synthetic data only Use anonymized production snapshots Match data volume — a migration working on 1K rows may lock on 10M Reproduce edge cases: NULLs, empty strings, max-length, unicode
Tested against production-like data volume Rollback written and tested Backup of affected tables created App code compatible with both old and new schema Execution time benchmarked on staging Lock impact analyzed Replication lag monitoring in place
Monitor lock waits and active queries Monitor replication lag Watch for error rate spikes Keep rollback command ready
Schema matches expected state Integration tests pass against migrated DB Data integrity validated (row counts, checksums) ORM schema / type definitions updated Deprecated structures cleaned up after cool-down Migration documented in team runbook
NEVER run untested migrations directly in production NEVER drop a column without first removing all application references and deploying NEVER add NOT NULL to a large table without a default value in a single statement NEVER mix schema DDL and data mutations in the same migration file NEVER skip the dual-write phase when renaming columns in a live system NEVER assume migrations are instantaneous — always benchmark on production-scale data NEVER disable foreign key checks to "speed up" migrations in production NEVER deploy application code that depends on a schema change before the migration has completed
Code helpers, APIs, CLIs, browser automation, testing, and developer operations.
Largest current source with strong distribution and engagement signals.