ホームページ データベース mysql チュートリアル mysqldump,source数据备份与还原方法

mysqldump,source数据备份与还原方法

Jun 07, 2016 pm 05:52 PM

文章介绍了mysql中的mysqldump,source命令进行数据备份与还原方法,有需要的朋友可参考一下本文章哦。

还原一个数据库:

 代码如下 复制代码
mysql -h localhost -u root -p123456 www

备份一个数据库:

 代码如下 复制代码
mysqldump -h localhost -u root -p123456 www > d:/www2008-2-26.sql

本地:
1.进入MySQL目录下的bin文件夹:e:回车;

e:>cd mysqlbin  回车

2.导出数据库:mysqldump -u 用户名 -p 数据库名 > 导出的文件名

 代码如下 复制代码
mysqldump -uroot -p abc > abc.sql

(导出数据库abc到abc.sql文件)
提示输入密码时,输入该数据库用户名的密码(如果导出单张表的话在数据库名后面输入表名即可)

如果提示locktable错误:则在mysqldump -uroot -p abc后面空一格加上--skip-lock-tables

3、会看到文件news.sql自动生成到bin文件下


.Linux下MySQL的备份与还原
2.1 备份

 代码如下 复制代码
[root@localhost ~]# cd /var/lib/mysql (进入到MySQL库目录,根据自己的MySQL的安装情况调整目录)
[root@localhost mysql]# mysqldump -u root -p voice>voice.sql,输入密码即可。

2.2 还原

 代码如下 复制代码
法一:
[root@localhost ~]# mysql -u root -p 回车,输入密码,进入MySQL的控制台"mysql>",同1.2还原。
法二:
[root@localhost ~]# cd /var/lib/mysql (进入到MySQL库目录,根据自己的MySQL的安装情况调整目录)
[root@localhost mysql]# mysql -u root -p voice


常用命令


备份MySQL数据库的命令
mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql

备份MySQL数据库为带删除表的格式
备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。

 代码如下 复制代码
mysqldump -–add-drop-table -uusername -ppassword databasename > backupfile.sql

直接将MySQL数据库压缩备份

 代码如下 复制代码
mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz

备份MySQL数据库某个(些)表

 代码如下 复制代码
mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql

同时备份多个MySQL数据库

 代码如下 复制代码
mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql

仅仅备份数据库结构

 代码如下 复制代码
mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql

备份服务器上所有数据库

 代码如下 复制代码
mysqldump –all-databases > allbackupfile.sql

还原MySQL数据库的命令

 代码如下 复制代码
mysql -hhostname -uusername -ppassword databasename

还原压缩的MySQL数据库
gunzip

将数据库转移到新服务器

 代码如下 复制代码
mysqldump -uusername -ppassword databasename | mysql –host=*.*.*.* -C databasename

 

1、mysqldump 详解

1.1 备份

mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。
现在来讲一下 mysqldump 的一些主要参数:

--compatible=name

它告诉 mysqldump,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容。值可以为 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用几个值,用逗号将它们隔开。当然了,它并不保证能完全兼容,而是尽量兼容。

--complete-insert,-c

导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行。这么做能提高插入效率,但是可能会受到 max_allowed_packet 参数的影响而导致插入失败。因此,需要谨慎使用该参数,至少我不推荐。

--default-character-set=charset

指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。

--disable-keys

告诉 mysqldump 在 INSERT 语句的开头和结尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 语句,这能大大提高插入语句的速度,因为它是在插入完所有数据后才重建索引的。该选项只适合 MyISAM 表。

--extended-insert = true|false

默认情况下,mysqldump 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,设定它的值为 false 即可。

--hex-blob

使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用本选项。影响到的字段类型有 BINARY、VARBINARY、BLOB。

--lock-all-tables,-x

在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single-transaction 和 --lock-tables 选项。

--lock-tables

它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项。

--no-create-info,-t

只导出数据,而不添加 CREATE TABLE 语句。

--no-data,-d

不导出任何数据,只导出数据库表结构。

--opt

这只是一个快捷选项,等同于同时添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 选项。本选项能让 mysqldump 很快的导出数据,并且导出的数据能很快导回。该选项默认开启,但可以用 --skip-opt 禁用。注意,如果运行 mysqldump 没有指定 --quick 或 --opt 选项,则会将整个结果集放在内存中。如果导出大数据库的话可能会出现问题。

--quick,-q

该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。

--routines,-R

导出存储过程以及自定义函数。

--single-transaction

该选项在导出数据之前提交一个 BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于事务表,例如 InnoDB 和 BDB。
本选项和 --lock-tables 选项是互斥的,因为 LOCK TABLES 会使任何挂起的事务隐含提交。
要想导出大表的话,应结合使用 --quick 选项。

--triggers

同时导出触发器。该选项默认启用,用 --skip-triggers 禁用它。

其他参数详情请参考手册,我通常使用以下 SQL 来备份 MyISAM 表:

 代码如下 复制代码

/usr/local/mysql/bin/mysqldump -uyejr -pyejr
--default-character-set=utf8 --opt --extended-insert=false
--triggers -R --hex-blob -x db_name > db_name.sql

使用以下 SQL 来备份 Innodb 表:

 代码如下 复制代码

/usr/local/mysql/bin/mysqldump -uyejr -pyejr
--default-character-set=utf8 --opt --extended-insert=false
--triggers -R --hex-blob --single-transaction db_name > db_name.sql

另外,如果想要实现在线备份,还可以使用 --master-data 参数来实现,如下:

 代码如下 复制代码

/usr/local/mysql/bin/mysqldump -uyejr -pyejr
--default-character-set=utf8 --opt --master-data=1
--single-transaction --flush-logs db_name > db_name.sql

它只是在一开始的瞬间请求锁表,然后就刷新binlog了,而后在导出的文件中加入CHANGE MASTER 语句来指定当前备份的binlog位置,如果要把这个文件恢复到slave里去,就可以采用这种方法来做。

1.2 还原

用 SOURCE 语法

其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:

 代码如下 复制代码

SOURCE /tmp/db_name.sql;

这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu システムでの Source Insight の使用方法の分析 Ubuntu システムでの Source Insight の使用方法の分析 Jan 08, 2024 pm 11:49 PM

Windows で SourceInsight を使ってソース コードを読み込んで解析することに慣れている友人も多いと思いますが、確かに LINUX ではもっと効率的なツールがありますが、設定が面倒で面倒です。ぜひ使いたいと思っている人も多いと思います。 Linux 環境では SourceInsight を使用できます。Ubuntu での SourceInsight の使用方法を次のエディターで詳しく説明します。一緒に見に行きましょう!これは私のシステム情報です: Linuxgavin-laptop2.6.32-40-generic#87-UbuntuSMPTueMar600:56:56UTC2012x86_64GNU/Li

ソースはどのボタンですか? ソースはどのボタンですか? Oct 10, 2023 pm 03:26 PM

ソースは、入力信号ソースを切り替えるか、別の入力ソースを選択するためのボタンです。通常、テレビ、プロジェクター、サウンド システム、コンピューター モニター、その他の機器に使用されます。テレビのソース ボタンを使用すると、ユーザーはさまざまな入力ソースを切り替えて、テレビでさまざまなコンテンツを再生できます。プロジェクターのソース ボタンには同様の機能があり、さまざまなデバイスをプロジェクターに接続できます。オーディオ システムでは、ソース ボタンを使用して、さまざまなオーディオ入力ソースを切り替えます。コンピューターのモニターでは、ソース ボタンはテレビやプロジェクターなどと同様に機能します。

Docker Compose、Nginx、MariaDB を介した PHP アプリケーションのデータのバックアップと復元 Docker Compose、Nginx、MariaDB を介した PHP アプリケーションのデータのバックアップと復元 Oct 12, 2023 am 11:14 AM

DockerCompose、Nginx、MariaDB を介した PHP アプリケーションのデータ バックアップと復元 クラウド コンピューティングとコンテナ化テクノロジの急速な発展に伴い、展開と実行に Docker を使用するアプリケーションがますます増えています。 Docker エコシステムでは、DockerCompose は単一の構成ファイルを通じて複数のコンテナーを定義および管理できる非常に人気のあるツールです。この記事ではDockerCompose、Ngの使い方を紹介します。

ThinkPHP6 データのバックアップとリカバリ: データのセキュリティの確保 ThinkPHP6 データのバックアップとリカバリ: データのセキュリティの確保 Aug 13, 2023 am 08:28 AM

ThinkPHP6 データのバックアップとリカバリ: データのセキュリティの確保 インターネットの急速な発展に伴い、データは非常に重要な資産になりました。したがって、データのセキュリティは非常に重要です。 Web アプリケーション開発では、データのバックアップとリカバリはデータのセキュリティを確保するための重要な部分です。この記事では、ThinkPHP6 フレームワークを使用してデータのバックアップと復元を行い、データのセキュリティを確保する方法を紹介します。 1. データのバックアップ データのバックアップとは、データベース内のデータを何らかの方法でコピーまたは保存することを指します。この方法では、データが

C++ ビッグ データ開発におけるデータ バックアップの一貫性の問題にどう対処するか? C++ ビッグ データ開発におけるデータ バックアップの一貫性の問題にどう対処するか? Aug 26, 2023 pm 11:15 PM

C++ ビッグ データ開発におけるデータ バックアップの一貫性の問題にどのように対処しますか? C++ ビッグ データ開発において、データ バックアップは非常に重要な部分です。データバックアップの一貫性を確保するには、この問題を解決するための一連の対策を講じる必要があります。この記事では、C++ ビッグ データ開発におけるデータ バックアップの一貫性の問題に対処する方法について説明し、対応するコード例を示します。データのバックアップにトランザクションを使用する トランザクションは、データ操作の一貫性を確保するためのメカニズムです。 C++ では、データベース内のトランザクションの概念を使用してデータのバックアップを実装できます。

Laravelを使用してデータのバックアップとリカバリ機能を実装する方法 Laravelを使用してデータのバックアップとリカバリ機能を実装する方法 Nov 02, 2023 pm 01:18 PM

Laravel を使用してデータのバックアップと復元機能を実装する方法 インターネットの発展に伴い、データのバックアップと復元機能が重要なニーズになりました。 Web アプリケーションでは、データのバックアップと復元機能により、データのセキュリティと信頼性を確保し、緊急事態に対処する緊急手段も提供します。人気の PHP フレームワークである Laravel は強力なデータ処理機能とデータベース操作機能を備えているため、データのバックアップと回復機能を簡単に実装できます。この記事ではLaravelを使ってデータバックアップを実装する方法を紹介します。

データのバックアップと障害復旧: クラスター モードでの MySQL マスター/スレーブ レプリケーションの重要性についてのディスカッション データのバックアップと障害復旧: クラスター モードでの MySQL マスター/スレーブ レプリケーションの重要性についてのディスカッション Sep 08, 2023 am 09:03 AM

データのバックアップと障害回復: クラスター モードでの MySQL マスター/スレーブ レプリケーションの重要性についての議論 はじめに: 近年、データの規模と複雑さが継続的に増大するため、データベースのバックアップと障害回復が特に重要になってきています。分散システムでは、高可用性とフォールト トレランスを提供するために、MySQL マスター/スレーブ レプリケーションがクラスター モードで広く使用されています。この記事では、クラスター モードでの MySQL マスター/スレーブ レプリケーションの重要性を検討し、いくつかのコード例を示します。 1. MySQL マスター/スレーブ レプリケーションの基本原理と利点 MySQL マスター/スレーブ レプリケーションは、一般的な

PHPプロジェクトにデータのバックアップとリカバリ機能を実装するにはどうすればよいですか? PHPプロジェクトにデータのバックアップとリカバリ機能を実装するにはどうすればよいですか? Nov 04, 2023 pm 04:30 PM

PHPプロジェクトにデータのバックアップとリカバリ機能を実装するにはどうすればよいですか? PHP プロジェクトの開発および管理のプロセスでは、データのバックアップおよびリカバリ機能が非常に重要です。偶発的なデータ損失を避けるためでも、プロジェクトの移行やアップグレード中にデータのセキュリティを確保するためでも、データのバックアップとリカバリの方法をマスターする必要があります。この記事では、PHP プロジェクトにデータのバックアップと復元機能を実装する方法を紹介します。 1. データ バックアップ定義のバックアップ パス: まず、バックアップ ファイルの保存に使用するパスを定義する必要があります。プロジェクト構成ファイルで定義可能

See all articles