技能 编程开发 数据库迁移最佳实践

数据库迁移最佳实践

v20260517
database-migrations
本文提供了一份全面的数据库迁移最佳实践指南。它涵盖了针对PostgreSQL、MySQL等主流数据库和各类型ORM的模式更改、数据迁移及回滚操作。核心目标是确保在生产环境中实现安全、可逆且零停机时间的数据库升级。
获取技能
175 次下载
概览

データベースマイグレーションパターン

本番環境システム用の安全で可逆的なデータベーススキーマ変更。

アクティベーション時期

  • データベーステーブルの作成または変更
  • 列またはインデックスの追加/削除
  • データマイグレーション(バックフィル、変換)の実行
  • ゼロダウンタイムスキーマ変更を計画
  • 新しいプロジェクト用のマイグレーションツール設定

コア原則

  1. すべての変更はマイグレーション — 本番環境データベースを手動で変更しない
  2. マイグレーションは本番環境で前方のみ — ロールバックは新しい前向きマイグレーション使用
  3. スキーマとデータマイグレーションは分離 — 1つのマイグレーションでDDLとDMLを混ぜない
  4. 本番環境サイズのデータに対してマイグレーションをテスト — 100行で機能するマイグレーション10M上でロックされる場合がある
  5. マイグレーションは展開後は不変 — 本番環境で実行されたマイグレーションを編集しない

マイグレーション安全チェックリスト

マイグレーションを適用する前に:

  • マイグレーションはUPとDOWNの両方を持つ(または明示的に不可逆としてマーク)
  • 大型テーブルの完全テーブルロックなし(並行操作使用)
  • 新しい列はデフォルトまたはnullable(デフォルトなしでNOT NULLを追加しない)
  • インデックスは並行して作成(既存テーブルのCREATE TABLEでインライン化しない)
  • データバックフィルはスキーマ変更から分離したマイグレーション
  • 本番環境データのコピーに対してテスト
  • ロールバック計画を文書化

PostgreSQL パターン

列を安全に追加

-- GOOD: Nullable列、ロックなし
ALTER TABLE users ADD COLUMN avatar_url TEXT;

-- GOOD: デフォルト付きの列(Postgres 11+は即座、書き直しなし)
ALTER TABLE users ADD COLUMN is_active BOOLEAN NOT NULL DEFAULT true;

-- BAD: 既存テーブルのデフォルトなしで NOT NULL(完全書き直し必須)
ALTER TABLE users ADD COLUMN is_active BOOLEAN NOT NULL;

詳細についてはドキュメントを参照してください。

信息
Category 编程开发
Name database-migrations
版本 v20260517
大小 2.79KB
更新时间 2026-05-18
语言