MySQLでのdumpの方法とは?基本的な使い方・指定テーブルのみdump・新規データベースを作成してリストアする方法

MySQLでのdumpの方法とは?
今回は、MySQLでのdumpの方法について紹介します。MySQLでは、テーブルやデータベースのバックアップ(dump)・リストアができます。目的は、サーバがクラッシュした時のためのバックアップやデータ移行です。
MySQLでのdumpの方法に興味のある方はぜひご覧ください。
dump対象
ここでは、dump対象のデータベース、テーブルは以下とします。データベース一覧を表示します。
1 2 3 4 5 6 7 8 9 10 11 |
mysql> SHOW DATABASES; +--------------------+ | Database | +--------------------+ | information_schema | | mydb | | mysql | | performance_schema | | phpmyadmin | | test | +--------------------+ |
mydbのテーブル一覧を表示します。
1 2 3 4 5 6 7 8 |
mysql> SHOW TABLES; +----------------+ | Tables_in_mydb | +----------------+ | book | | lang | | user | +----------------+ |
mydbのテーブルには、以下のデータが格納されています。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
mysql> SELECT * FROM user; +------+-------+ | id | name | +------+-------+ | 1 | user1 | | 2 | user2 | | 3 | user3 | | 4 | user4 | | 5 | user5 | +------+-------+ mysql> SELECT * FROM book; +------+-------+ | id | name | +------+-------+ | 1 | book1 | | 2 | book2 | | 3 | book3 | | 4 | book4 | | 5 | book5 | +------+-------+ mysql> SELECT * FROM lang; +------+--------+ | id | name | +------+--------+ | 1 | C# | | 2 | VB.NET | | 3 | Python | | 4 | PHP | | 5 | Ruby | +------+--------+ |
これらをdump、リストアする方法を以降の章で紹介します。
テーブルのdump
MySQLでのテーブルのdump方法を紹介します。コマンドプロンプトからmysqldumpコマンドを実行します。文法は以下の通りです。
1 |
mysqldump -uユーザ名 -p -hlocalhost データベース名 テーブル名 > dumpファイル名 |
1つのテーブルをdumpするには、以下のコマンドを実行します。
1 |
mysqldump -uroot -p -hlocalhost mydb user > C:\dump\user.dump |
テーブルは複数指定可能です。
1 |
mysqldump -uroot -p -hlocalhost mydb user book > C:\dump\user_book.dump |
このようにMySQLでは、mysqldumpコマンドでテーブルをdumpできます。
テーブルのリストア
MySQLでのテーブルのリストア方法を紹介します。コマンドプロンプトからmysqlコマンドを実行します。文法は以下の通りです。
1 |
mysql -uユーザ名 -p -hlocalhost データベース名 < dumpファイル名 |
新たにデータベースを作成し、先ほど作成したdumpファイルをリストアします。データベース名は「mydb2」とします。
1 2 3 4 |
mysql> CREATE DATABASE mydb2; mysql> USE mydb2; mysql> SHOW TABLES; Empty set (0.003 sec) |
以下のコマンドでリストアします。
1 |
mysql -uroot -p -hlocalhost mydb2 < C:\dump\user.dump |
実行後にテーブル一覧を確認すると、リストアされていることが分かります。
1 2 3 4 5 6 |
mysql> SHOW TABLES; +-----------------+ | Tables_in_mydb2 | +-----------------+ | user | +-----------------+ |
別のdumpファイルをリストアしてみます。
1 |
mysql -uroot -p -hlocalhost mydb2 < C:\dump\user_book.dump |
実行後にテーブル一覧を確認すると、リストアされていることが分かります。
1 2 3 4 5 6 7 |
mysql> SHOW TABLES; +-----------------+ | Tables_in_mydb2 | +-----------------+ | book | | user | +-----------------+ |
レコードもリストアされているか確認してみます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
mysql> SELECT * FROM book; +------+-------+ | id | name | +------+-------+ | 1 | book1 | | 2 | book2 | | 3 | book3 | | 4 | book4 | | 5 | book5 | +------+-------+ mysql> SELECT * FROM user; +------+-------+ | id | name | +------+-------+ | 1 | user1 | | 2 | user2 | | 3 | user3 | | 4 | user4 | | 5 | user5 | +------+-------+ |
このようにMySQLでは、mysqlコマンドでテーブルのリストアができます。
データベースのdump
MySQLでのデータベースのdump方法を紹介します。コマンドプロンプトからmysqldumpコマンドを実行します。文法は以下の通りです。
1 |
mysqldump -uユーザ名 -p -hlocalhost -B データベース名 [データベース名 ...] > dumpファイル名 |
以下のコマンドで指定データベースをdumpします。
1 |
mysqldump -uroot -p -hlocalhost -B mydb > C:\dump\mydb.dump |
以下のコマンドで全データベースをdumpします。
1 |
mysqldump -uroot -p -hlocalhost -A > C:\dump\alldb.dump |
このようにMySQLでは、mysqldumpコマンドでデータベースをdumpできます。
データベースのリストア
MySQLでのデータベースのリストア方法を紹介します。コマンドプロンプトからmysqlコマンドを実行します。文法は以下の通りです。
1 |
mysql -uユーザ名 -p -hlocalhost < dumpファイル名 |
データベースのリストアにはデータベース名は指定しません。試しにテーブルを削除します。
1 2 3 |
mysql> drop table user; mysql> drop table book; mysql> drop table lang; |
データベースをリストアします。
1 |
mysql -uroot -p -hlocalhost < C:\dump\mydb.dump |
テーブル一覧を表示すると、データベースがリストアされていることが分かります。
1 2 3 4 5 6 7 8 |
mysql> SHOW TABLES; +----------------+ | Tables_in_mydb | +----------------+ | book | | lang | | user | +----------------+ |
mydb.dumpファイルをテキストエディタで編集し、mydbをmydb3に置換します。mydb3.dumpというファイル名で保存します。こうすることで、データベース「mydb3」が作成され、データがリストアされます。
1 |
mysql -uroot -p -hlocalhost < C:\dump\mydb3.dump |
mydb3のテーブル一覧を確認すると、データベースがリストアされていることが分かります。
1 2 3 4 5 6 7 8 9 |
mysql> USE mydb3; mysql> SHOW TABLES; +-----------------+ | Tables_in_mydb3 | +-----------------+ | book | | lang | | user | +-----------------+ |
このようにMySQLでは、mysqlコマンドでデータベースのリストアができます。
まとめ
いかがでしたでしょうか。MySQLでのdumpの方法について紹介しました。MySQLでは、テーブルやデータベースのバックアップ(dump)・リストアができます。
ぜひご自身でMySQLのコマンドを書いて、理解を深めてください。
FEnetを運営しているネプラス株式会社はサービス開始から10年以上
『エンジニアの生涯価値の向上』をミッションに掲げ、
多くのインフラエンジニア・ネットワークエンジニアの就業を支援してきました。
ネプラス株式会社はこんな会社です
秋葉原オフィスにはネプラス株式会社をはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
インフラ業界に特化
ネットワーク・サーバー・データベース等、ITインフラ業界に特化。Cisco Systemsプレミアパートナーをはじめ各種ベンダーのパートナー企業です。
業界を知り尽くしているからこそ大手の取引先企業、経験豊富なエンジニアに選ばれています。
-
正社員なのにフリーランスのような働き方
正社員の方でも希望を聞いたうえでプロジェクトをアサインさせていただいており、フリーランスのような働き方が可能。帰社日もありません。
プロジェクト終了後もすぐに次の案件をご紹介させていただきますのでご安心ください。
-
大手直取引の高額案件
案件のほとんどが大手SIerやエンドユーザーからの直取引のためエンジニアの皆様へに高く還元できています。
Ciscoをはじめ、Juniper、Azure、Linux、AWS等インフラに特化した常時300件以上の案件があります。
-
スキルアップ支援
不要なコストを削減し、その分エンジニアの方へのスキルアップ支援(ネットワーク機器貸出、合格時の受験費用支給など)や給与で還元しています。
受験費用例)CCNP,CCIE:6-20万円、JNCIS:3-4万円、AWS:1-3万円など
※業務に関連する一定の資格のみ。各種条件がありますので詳しくは担当者へにお尋ねください。
-
現給与を保証します!※
前職の給与保証しており、昨年度は100%の方が給与アップを実現。収入面の不安がある方でも安心して入社していただけます。
※適用にはインフラエンジニアの業務経験1年以上、等一定の条件がございます。
-
インセンティブ制度
ネットワーク機器の販売・レンタル事業等、売上に貢献いただいた方にはインセンティブをお支払いしています。
取引先企業とエンジニア側、双方にメリットがあり大変好評をいただいています。
-
社会保険・福利厚生
社員の方は、社会保険を完備。健康保険は業界内で最も評価の高い「関東ITソフトウェア健康保険組合」です。
さらに様々なサービスをお得に利用できるベネフィットステーションにも加入いただきます。
-
東証プライム上場企業グループ
ネプラスは東証プライム上場「株式会社夢真ビーネックスグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
ネプラス株式会社に興味を持った方へ
ネプラス株式会社では、インフラエンジニアを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。


MySQL新着案件New Job
サーバ構築・運用設計/東京都渋谷区/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収588万~588万円東京都渋谷区(渋谷駅)【高額年収】/基盤運用保守/東京都千代田区/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収600万~720万円東京都千代田区(溜池山王駅)【高額年収】/国内クラウドシステムのサーバ運用保守/東京都新宿区/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収600万~720万円東京都新宿区(東新宿駅)国内クラウドシステムのサーバ構築のテスター/東京都新宿区/【WEB面談可/インフラサーバ経験者/20~40代の方活躍中】/在宅勤務
年収300万~420万円東京都新宿区(東新宿駅)【高額年収】/社内情報システムインフラ運用保守/Windows/東京都多摩北部/【WEB面談可】/在宅勤務/20代~30代の方活躍中
年収600万~720万円東京都多摩北部(-駅)社内情報システムインフラ構築のテスター/Windows/東京都多摩北部/【WEB面談可】/在宅勤務/20代~30代の方活躍中
年収300万~420万円東京都多摩北部(-駅)