目次
- はじめに
- WordPressデータベース移行の基本概念
- 実践!WordPressデータベース移行の手順
- 1. 事前準備とバックアップ
- 2. データベースのエクスポート
- 3. WordPressファイルの転送
- 4. 新しいデータベースの作成とインポート
- 5. wp-config.php の設定変更
- 6. サイトURLの更新
- プラグインによるWordPressデータベース移行
- WordPressデータベース移行でよくある問題と解決策
- 1. データベース接続エラー(Error establishing a database connection)
- 2. サイトが真っ白になる(White Screen of Death)
- 3. 画像が表示されない、リンク切れ
- 4. シリアライズ化されたデータの問題
- 実践的なヒントとベストプラクティス
- まとめ
はじめに
WordPressサイトを運営されていらっしゃる皆様にとって、サーバー移転、ドメイン変更、あるいは開発環境から本番環境へのデプロイといった局面において、「WordPressデータベース移行」は避けて通れない重要な作業でございます。この作業を安全かつ確実に行うことは、サイトの安定稼働とビジネスの継続性に直結いたします。
本稿では、WordPressデータベース移行の具体的な手順、実践的な方法、よくある問題とその解決策、そして成功のためのベストプラクティスについて、真摯にご説明させていただきます。皆様のWordPressデータベース移行がスムーズに完了するよう、詳細な情報を提供いたしますので、ぜひご一読ください。
WordPressデータベース移行の基本概念
データベースとは何か?
WordPressは、投稿記事、コメント、ユーザー情報、サイト設定、プラグインやテーマのデータなど、動的なコンテンツのほとんどをデータベースに保存しております。これらのデータは、通常、MySQLまたはMariaDBといったリレーショナルデータベース管理システムによって管理されており、WordPressサイトの「心臓部」とも言える存在でございます。
なぜデータベース移行が必要なのか?
WordPressデータベース移行が必要となる主なシナリオは以下の通りでございます。
- サーバーの変更: レンタルサーバー会社間の移転や、VPS/クラウドサーバーへの移行時に、サイトのデータと設定を新しい環境へ移す必要がございます。
- ドメイン名の変更: サイトのURLを
old-domain.comからnew-domain.comへ変更する際、データベース内の古いURLを新しいURLに更新する必要がございます。 - 開発環境から本番環境へのデプロイ: ローカル環境やステージング環境で開発したサイトを、公開用の本番環境へ移す際にデータベース移行が伴います。
- バックアップからの復元: 何らかのトラブルが発生した際に、取得済みのバックアップデータ(データベースとファイル)を復元する場合も、データベース移行の一種でございます。
実践!WordPressデータベース移行の手順
ここからは、手動によるWordPressデータベース移行の具体的な手順について解説いたします。一見複雑に思えるかもしれませんが、一つ一つのステップを丁寧に進めることで、確実な移行が可能でございます。
1. 事前準備とバックアップ
移行作業に着手する前に、必ず現在のWordPressサイトのファイル一式(WordPressコア、テーマ、プラグイン、アップロードディレクトリなど)とデータベースの完全なバックアップを取得してください。万が一の事態に備え、このバックアップは非常に重要でございます。
2. データベースのエクスポート
現在のサーバーからWordPressデータベースをエクスポートいたします。
phpMyAdminを利用する方法
現在のサーバーのphpMyAdminにログインし、対象のデータベースを選択いたします。「エクスポート」タブをクリックし、「カスタム」方式を選択してください。「構造」と「データ」の両方にチェックを入れ、出力形式を「SQL」に設定し、圧縮は「なし」または「gzip」を選択して実行することで、SQLファイルがダウンロードされます。
WP-CLIを利用する方法
SSHでサーバーに接続できる場合、WP-CLIは非常に強力なツールでございます。WordPressのルートディレクトリに移動し、以下のコマンドを実行することで、データベースをSQLファイルとしてエクスポートできます。</n
wp db export backup.sql
3. WordPressファイルの転送
FTP/SFTPクライアント、またはSSH経由で、WordPressのコアファイル、テーマ、プラグイン、アップロードディレクトリ(wp-content)を含むすべてのファイルを新しいサーバーへ転送いたします。新しいサーバーのWebルートディレクトリ(通常はpublic_htmlやwww)に配置してください。
4. 新しいデータベースの作成とインポート
新しいサーバーのコントロールパネル(cPanel, Pleskなど)またはphpMyAdminで、新しいデータベースとデータベースユーザーを作成し、そのユーザーにデータベースへの完全なアクセス権限を付与いたします。
次に、作成したデータベースに、エクスポートしたSQLファイルをインポートいたします。

phpMyAdminを利用する方法
新しいサーバーのphpMyAdminにログインし、作成したデータベースを選択いたします。「インポート」タブをクリックし、「ファイルを選択」からエクスポートしたSQLファイルを選択して実行いたします。
WP-CLIを利用する方法
新しいサーバーにSSHで接続し、WordPressのルートディレクトリに移動した後、以下のコマンドを実行してSQLファイルをインポートいたします。</n
wp db import backup.sql
5. wp-config.php の設定変更
転送したWordPressファイルのルートディレクトリにあるwp-config.phpファイルを編集し、新しいデータベースの接続情報に更新いたします。以下の箇所を修正する必要がございます。
define( 'DB_NAME', '新しいデータベース名' );
define( 'DB_USER', '新しいデータベースユーザー名' );
define( 'DB_PASSWORD', '新しいデータベースパスワード' );
define( 'DB_HOST', '新しいデータベースホスト名' ); // 通常は 'localhost' またはサーバー指定のホスト名
6. サイトURLの更新
ドメイン名を変更する場合、データベース内のサイトURLを新しいものに更新する必要がございます。この手順はWordPressデータベース移行において非常に重要でございます。
SQLクエリを利用する方法(推奨)
phpMyAdminまたはWP-CLIで以下のSQLクエリを実行いたします。new-domain.comとold-domain.comは、ご自身の新しいドメインと古いドメインにそれぞれ置き換えてください。また、http://とhttps://の違いにもご注意ください。
UPDATE wp_options SET option_value = REPLACE(option_value, 'http://old-domain.com', 'http://new-domain.com') WHERE option_name = 'home' OR option_name = 'siteurl';
UPDATE wp_posts SET guid = REPLACE(guid, 'http://old-domain.com','http://new-domain.com');
UPDATE wp_posts SET post_content = REPLACE(post_content, 'http://old-domain.com', 'http://new-domain.com');
UPDATE wp_postmeta SET meta_value = REPLACE(meta_value,'http://old-domain.com','http://new-domain.com');
※wp_はデータベースのテーブルプレフィックスです。ご自身の環境に合わせて変更してください。
WP-CLIを利用する方法
WP-CLIのsearch-replaceコマンドは、シリアライズ化されたデータも正確に処理できるため、非常に強力で安全な方法でございます。
まず、--dry-runオプションで変更内容を事前確認し、問題がなければ--dry-runを外して実行いたします。
wp search-replace 'http://old-domain.com' 'http://new-domain.com' --dry-run
wp search-replace 'http://old-domain.com' 'http://new-domain.com' --all-tables
プラグインを利用する方法
Better Search Replaceなどのプラグインを利用して、WordPressの管理画面からデータベース内の文字列を一括置換することも可能でございます。この方法は、WP-CLIが利用できない環境で特に有効です。

プラグインによるWordPressデータベース移行
手動でのWordPressデータベース移行作業に不安がある場合や、より手軽に移行を行いたい場合には、WordPressの移行プラグインが非常に有効でございます。
主なプラグインの例
- All-in-One WP Migration: サイト全体(データベースとファイル)を一つのファイルとしてエクスポートし、新しい環境にインポートするだけで移行が完了いたします。非常に直感的で、初心者の方にもおすすめでございます。ただし、無料版ではアップロードファイルのサイズに制限がございます。
- Duplicator: サイトの複製と移行に特化したプラグインで、インストーラーとアーカイブファイルを作成し、新しいサーバーで実行することでサイトを再構築いたします。より詳細な設定が可能でございます。
これらのプラグインを使用する際も、必ず事前バックアップは怠らないでください。また、大規模なサイトや複雑な設定のサイトでは、手動でのWordPressデータベース移行の方が安定する場合もございますので、状況に応じてご検討ください。

WordPressデータベース移行でよくある問題と解決策
WordPressデータベース移行の過程で、いくつかの問題に直面することがございます。ここでは、特によくある問題とその解決策をご紹介いたします。

1. データベース接続エラー(Error establishing a database connection)
原因: wp-config.phpに記述されているデータベース接続情報(DB_NAME、DB_USER、DB_PASSWORD、DB_HOST)が間違っている可能性がございます。
解決策: 新しいデータベースの接続情報を再度確認し、正確にwp-config.phpに記述してください。特に、ホスト名がlocalhostではない場合もございますので、サーバーの情報を確認することが重要でございます。
2. サイトが真っ白になる(White Screen of Death)
原因: PHPエラー、メモリ不足、プラグインやテーマの競合、あるいはファイルパーミッションの問題などが考えられます。
解決策: まず、wp-config.phpにdefine('WP_DEBUG', true);を追加してデバッグモードを有効にし、エラーメッセージを確認してください。エラーメッセージから原因を特定できる場合がございます。また、すべてのプラグインを無効化し、デフォルトテーマ(Twenty Twenty-Fourなど)に変更して問題が解決するかお試しください。ファイルやディレクトリのパーミッションが正しく設定されているかもご確認ください。
3. 画像が表示されない、リンク切れ
原因: データベース内のURL置換が不完全であるか、ファイルパスが古いままになっている可能性がございます。特に、投稿コンテンツ内の画像URLや、メディアライブラリのパスが古いドメインを指していることが原因です。
解決策: サイトURLの更新手順を再度確認し、特にpost_contentやpostmetaテーブル内のURLが正しく置換されているかご確認ください。WP-CLIのsearch-replaceコマンドは、これらの問題を解決するのに非常に有効でございます。また、画像ファイル自体が新しいサーバーに正しくアップロードされているかも確認してください。
4. シリアライズ化されたデータの問題
原因: WordPressはウィジェット設定、一部のプラグイン設定、カスタムフィールドのデータなどをシリアライズ化された形式でデータベースに保存いたします。単純な文字列置換(例:テキストエディタでの一括置換)では、このシリアライズ化されたデータの長さ情報が壊れてしまい、データが破損する問題が発生することがございます。
解決策: この問題はWordPressデータベース移行の際によく発生いたします。WP-CLIのwp search-replaceコマンドはシリアライズ化されたデータも正しく処理いたしますので、このコマンドの利用を強く推奨いたします。WP-CLIが利用できない場合は、Better Search Replaceプラグインなどの、シリアライズ化されたデータに対応したツールのご利用をご検討ください。
実践的なヒントとベストプラクティス
WordPressデータベース移行を成功させるための、いくつかの重要なヒントとベストプラクティスを共有いたします。
- 徹底した事前バックアップ: 何度も申し上げますが、移行作業は予測不能な問題が発生する可能性がございます。常に最新のバックアップを保持し、いつでも元の状態に戻せるようにしてください。
- テスト環境での事前確認: 本番環境へ移行する前に、必ずステージング環境やローカル環境で移行手順を試し、問題なく動作することを確認してください。これにより、本番環境でのリスクを最小限に抑えることができます。
- 段階的な移行: 大規模なサイトの場合、一度にすべての変更を行うのではなく、段階的に移行を進めることも検討してください。例えば、まずデータベースを移行し、次にファイルを移行するなど、リスクを分散させる方法です。
- キャッシュのクリア: WordPressデータベース移行が完了したら、WordPressのキャッシュプラグイン、サーバー側のキャッシュ(LiteSpeed Cacheなど)、CDNのキャッシュ、そしてブラウザのキャッシュをすべてクリアし、新しいサイトが正しく表示されることを確認してください。
- SSL/TLS設定の確認:
httpからhttpsへ移行する場合や、既存のSSL環境を引き継ぐ場合は、データベース内のURL置換をhttpsに統一し、新しいサーバーでのSSL証明書の設定も適切に行う必要がございます。 - DNS伝播時間の考慮: ドメインのDNS設定を変更した場合、新しいサーバーへの切り替えにはDNSの伝播時間(数時間から最大48時間程度)がかかることがございます。この期間は古いサーバーと新しいサーバーの両方がアクセスされうるため、一時的なデータ不整合を避けるための対策(古いサーバーでの書き込み停止など)もご検討ください。
まとめ
WordPressデータベース移行は、WordPressサイトを運営する上で避けては通れない重要なタスクでございます。手動での厳密な手順、WP-CLIの活用、または便利な移行プラグインの利用など、様々な方法がございますが、いずれの場合も事前のバックアップと慎重な作業が成功の鍵を握っております。

本稿でご紹介いたしました具体的な手順、よくある問題とその解決策、そして実践的なヒントをご参考に、皆様のWordPressデータベース移行が安全かつスムーズに完了することを心より願っております。ご不明な点がございましたら、専門家へのご相談もご検討いただくことをお勧めいたします。





