Heim >Datenbank >MySQL-Tutorial >Analyse der Befehlsmethode der MySQL-Sicherungs- und Wiederherstellungsbibliothek (langer Artikel)
Bezüglich der Methode zum Sichern und Wiederherstellen der MySQL-Datenbank sprechen wir hier zunächst über das Sicherungstool: Führen Sie mit dem MySQLhotcopy-Tool eine schnelle Sicherung durch und verwenden Sie anschließend den MySQL-Befehl. Sie müssen die Datenbanktabelle exportieren. Für eine ausführliche Einführung müssen Sie diesen Artikel lesen.
Sichern Sie die Datenbank regelmäßig, um Verluste zu minimieren, wenn unerwartete Situationen auftreten.
mysqldump ist ein von MySQL bereitgestelltes Datenbanksicherungstool. Wenn der Befehl mysqldump ausgeführt wird, wird die Datenbank in einer Textdatei gesichert mehrere CREATE- und INSERT-Anweisungen, verwenden Sie diese Anweisungen, um Tabellen neu zu erstellen und Daten einzufügen;
[Verwenden Sie mysqldump, um eine einzelne Datenbank zu sichern]
mysqldump -u user -h host -p password dbname>filename.sql
[Verwenden Sie mysqldump, um bestimmte Tabellen zu sichern die Datenbank]
mysqldump -u user -h host -p password dbname[tbname,[tbname…]]>filename.sql
[Verwenden Sie mysqldump, um mehrere Datenbanken zu sichern]
mysqldump -u user -h host -p password --databases[dbname,[dbname…]]>filename.sql
Nach der Verwendung des Parameters --databases müssen Sie den Namen mindestens einer Datenbank angeben und zum Trennen Leerzeichen verwenden mehrere Datenbanken;
【Alle Datenbanken im System sichern】
mysqldump -u user -h host -p password --all-databases>filename.sql
Tipp: Wenn Sie auf dem Server sichern und die Tabellen alle MyISAM sind, sollten Sie die Verwendung von mysqlhotcopy in Betracht ziehen, da dies möglich ist schneller sichern und wiederherstellen;
Da die MySQL-Tabelle als Datei gespeichert wird, können Sie das Speicherverzeichnis und die Dateien der MySQL-Datenbank direkt kopieren Sicherung.
Dies ist eine einfache, schnelle und effektive Sicherungsmethode. Um die Konsistenz der Sicherung aufrechtzuerhalten, müssen Sie vor der Sicherung die Operation LOCK TABLES für die relevanten Tabellen und dann FLUSH TABLES für die Tabelle ausführen (. Stellen Sie sicher, dass alle aktiven Indexseiten auf die Festplatte geschrieben werden. Dadurch können andere Benutzer die Tabelle weiterhin abfragen, während die Dateien im Datenbankverzeichnis kopiert werden.
Diese Methode ist nicht auf Tabellen in der InnoDB-Speicher-Engine anwendbar. Es ist am besten, die gesicherten Daten mit dieser Methode auf derselben Version des Servers wiederherzustellen.
kann nur auf dem Computer ausgeführt werden, auf dem sich das Datenbankverzeichnis befindet, und kann nur Tabellen vom Typ MyISAM und ARCHIVE sichern
1 MySQL-Befehle zum Wiederherstellen
mysql -u username -p [dbname] < filename.sql
source filename
2. Direkt in das Datenbankverzeichnis kopieren
Wenn die Datenbank durch Kopieren der Datenbankdatei gesichert wird, können Sie die gesicherte Datei direkt kopieren zur Wiederherstellung in das MySQL-Datenverzeichnis kopieren.
Bei der Wiederherstellung mit dieser Methode müssen die Hauptversionsnummern der Sicherungsdatenbank und des wiederherzustellenden Datenbankservers gleich bleiben. Und diese Methode gilt nur für die Tabellen der MyISAM-Engine, nicht jedoch für die Tabellen der InnoDB-Engine.
Bei Linux/Unix-Betriebssystemen müssen Sie nach dem Kopieren der Datei den Benutzer oder die Benutzergruppe der Datei in den Benutzer und die Gruppe ändern, in der MySQL ausgeführt wird, und die Gruppe auch mysql;
3. mysqlhotcopy-Schnellwiederherstellung
Die von mysqlhotcopy gesicherten Dateien können auch zum Wiederherstellen der Datenbank verwendet werden. Kopieren Sie die gesicherten Datenbankdateien an den Speicherort wo MySQL gespeichert ist (MySQL-Datenordner). Starten Sie einfach den MySQL-Dienst neu.
Wenn Sie diesen Vorgang als Root-Benutzer ausführen, müssen Sie den Eigentümer der Datenbankdatei angeben
chown -R mysql.mysql /var/lib/mysql/dbname cp -R /usr/backup/test usr/local/mysql/data
Tipps: Wenn die Datenbank, die wiederhergestellt werden muss, bereits vorhanden ist, kann die Wiederherstellung nur erfolgreich sein, nachdem die vorhandene Datenbank mit der DROP-Anweisung gelöscht wurde. Außerdem müssen verschiedene Versionen von MySQL kompatibel sein 🎜>3. Datenbankmigration
Bei der Datenbankmigration werden Daten von einem System auf ein anderes verschoben. Die Datenmigration erfolgt aus folgenden Gründen:
相同版本的MySQL数据库之间的迁移就是指在主版本号相同的MySQL数据库之间进行数据库移动。
举例:
将www.abc.com主机上的MySQL数据库全部迁移到www.bcd.com主机上:
mysqldump -h www.abc.com -u root -ppassword dbname | mysql -h www.bcd.com -uroot -ppassword
说明:
mysqldump导入的数据直接通过管道符|,传给mysql命令导入到主机www.bcd.com数据库中,dbname为需要迁移的数据库名称,如果需要迁移全部的数据库,可以使用参数 --all-databases
MySQL服务器升级的时候,需要先停止服务,然后卸载旧版本,并安装新版本MySQL,这种更新方法很简单,如果想保留旧版本中的用户访问控制信息,需要备份MySQL中的mysql数据库,在新版本MySQL安装完成之后,重新读入mysql备份文件中的信息;
旧版本与新版本的字符集不同时,迁移过程需要对默认字符集进行修改,不然可能无法正常显示结果;
对于InnoDB引擎的表,一般只能使用mysqldump工具将数据导出,然后使用mysql命令导入到目标服务器上。
从新版本向旧版本迁移数据的时候,需要特别的小心,最好使用mysqldump命令导出,然后导入目标数据库中;
数据库迁移可以使用一些工具,例如在Windows系统下,可以使用MyODBC实现MySQL和SQL Server之间的迁移。
MySQL官方提供的工具MySQL Migration Toolkit也可以实现在不同数据库间进行数据迁移;
MySQL数据库中的数据可以导出成SQL文本文件、xml文件或者HTML文件。
MySQL数据库导出数据的时候,允许使用包含导出定义的SELECT语句进行数据导出操作。该文件被创建到服务器主机上,因此必须拥有文件写入权限(FILE权限),才能使用此语法。
语法格式:
SELECT columnlist FORM table WHERE condition INTO OUTFILE ‘filename’ [OPTIONS]
[OPTIONS]选项:
● FIELDS TERMINATED BY ‘value’
● FIELDS [OPTIONALLY] ENCLOSED BY ‘value’
● FIELDS ESCAPED BY ‘value’
● LINES STARTING BY ‘value’
● LINES TERMINATED BY ‘value’
说明:filename不能是一个已经存在的文件;
OPTIONS部分语法包括FIELDS部分的语法和LINES子句,其可能的取值有:
FIELDS TERMINATED BY ‘value’:
设置字段之间的分隔字符,可以为单个或者多个字符,默认情况下为制表符‘\t’
FIELDS [OPTIONALLY] ENCLOSED BY ‘value’:
设置字段的包围字符,只能为单个字符,如果使用了OPTIONALLY,则只有CHAR和VERCHAR等字符数据字段被包括;
FIELDS ESCAPED BY ‘value’:
设置如何写入或者读取特殊字符,只能为单个字符,即设置转义字符,默认值为“\”
LINES STARTING BY ‘value’:
设置每行数据开始字符,可以为单个或者多个,默认不使用任何字符
LINES TERMINATED BY ‘value’:
设置每行数据结尾的字符 可以为单个或者多个字符,默认值为‘\n’;
注意:FIELDS和LINES两个子句是可选的,如果同时指定,FIELDS必须位于LINES的前面;
mysqldump工具不仅可以将数据导出为包含CREATE、INSERT的SQL文件,也可以导出为纯文本文件;
mysqldump -T path-u root -p dbname [tables] [OPTIONS]
--OPTIONS选项:
● --fields-terminated-by=value
● --fields-enclosed-by=value
● --fields-optionally-enclosed-by=value
● --fields-escaped-by=value
● --lines-terminated-end-by=value
说明:只有指定了T参数才可以导出为纯文本文件;path表示导出数据的目录;tables为指定要导出表的名称;如果不指定,将导出数据库dbname中的所有的表;
[options]取值:
● --fields-terminated-by=value:
设置字段之间的分隔字符,可以为单个或者多个字符,默认情况下为制表符‘\t’
● --fields-enclosed-by=value:
设置字段的包围字符;
● --fields-optionally-enclosed-by=value:
设置字段的包围字符,只能为单个字符,如果使用了OPTIONALLY,则只有CHAR和VERCHAR等字符数据字段被包括;
● --fields-escaped-by=value:
控制如何写入或者读取特殊字符,只能为单个字符,及设置转义字符,默认为反斜线“\”;
● --lines-terminated-end-by=value:
设置每行数据结尾的字符,可以为单个或者多个字符,默认值为‘\n’
mysql是一个功能丰富的工具命令,使用MySQL还可以在命令行模式下执行SQL指令将查询结果导入到文本文件中。相比mysqldump,MySQL工具导出的结果可读性更强。
如果MySQL服务器是一个单独的机器,用户是在一个client上进行操作,用户要把数据导入到client机器上,可以使用mysql -e语句;
使用MySQL导出数据文本文件语句的基本格式如下:
mysql -u root -p --execute=”SELECT语句” dbname > filename.txt
使用MySQL命令还可以指定查询结果的显示格式:
如果某行记录字段很多,可能一行不能完全显示,可以使用--vartical参数,将每条记录分为多行显示;
【将查询结果导出到HTML文件中】
mysql -u root -p --html --execute=”SELECT语句” dbname > filename.html
【将查询结果导出到xml文件中】
mysql -u root -p --xml --execute=”SELECT语句” dbname > filename.xml
LOAD DATA INFILE 语句用于高速的从一个文本文件中读取行,并装入一个表中。文件名称必须为文字字符串。
LOAD DATA INFILE ‘路径+文件名.txt’ INTO TABLE tablename [OPTIONS] [IGNORE number LINES]
注意:如果导出的.txt文件中指定了一些特殊的字符,因此还原语句中也要指定这些字符,以确保还原之后数据的完整性和正确性;
--OPTIONS选项
● FIELDS TERMINATED BY ‘value’
● FIELDS [OPTIONALLY] ENCLOSED BY ‘value’
● FIELDS ESCAPED BY ‘value’
● LINES STARTING BY ‘value’
● LINES TERMINATED BY ‘value’
可以看到LOAD DATA 语句中,关键字INFILE后面的filename文件为导入数据的来源;
tablename表示待导入的数据表名称;
OPTIONS部分语法包括FIELDS部分的语法和LINES子句,其可能的取值有:
FIELDS TERMINATED BY ‘value’:
设置字段之间的分隔字符,可以为单个或者多个字符,默认情况下为制表符‘\t’
FIELDS [OPTIONALLY] ENCLOSED BY ‘value’:
设置字段的包围字符,只能为单个字符,如果使用了OPTIONALLY,则只有CHAR和VERCHAR等字符数据字段被包括;
FIELDS ESCAPED BY ‘value’:
设置如何写入或者读取特殊字符,只能为单个字符,即设置转义字符,默认值为“\”
LINES STARTING BY ‘value’:
设置每行数据开始字符,可以为单个或者多个,默认不使用任何字符
LINES TERMINATED BY ‘value’:
设置每行数据结尾的字符 可以为单个或者多个字符,默认值为‘\n’;
[IGNORE number LINES]
选项表示忽略文件开始处的行数,number表示忽略的行数。执行LOAD DATA语句需要FILE权限;
使用mysqlimport命令可以导入文本文件,并且不需要登录MySQL客户端。
使用mysqlimport语句需要指定所需的选项、导入的数据库名称以及导入的数据文件的路径和名称。
mysqlimport命令的基本语法如下:
mysqlimport -u root -p dbname filename.txt [OPTIONS]
[options]取值:
● --fields-terminated-by=value:
设置字段之间的分隔字符,可以为单个或者多个字符,默认情况下为制表符‘\t’
● --fields-enclosed-by=value:
● --fields-optional-enclosed-by=value: Legen Sie die umgebenden Zeichen des Feldes fest, Dies kann nur ein einzelnes Zeichen sein. Wenn OPTIONAL verwendet wird, sind nur Zeichendatenfelder wie CHAR und VERCHAR enthalten um Sonderzeichen zu schreiben oder zu lesen. Der Standardwert ist ● --lines-terminated-by= value: Legen Sie das Zeichen am Ende jeder Datenzeile fest, das aus einem oder mehreren Zeichen bestehen kann. Der Standardwert ist „n“● --ignore-lines=n Ignorieren die ersten n Zeilen der Datendatei; Hinweis: Der Befehl mysqlimport kann den Tabellennamen der importierten Datenbank nicht angeben. Der Name der Datentabelle wird durch den Namen der importierten Datei bestimmt Als Tabellenname wird der Dateiname verwendet. Die Tabelle muss vor dem Datenimport vorhanden sein. Verwandte Empfehlungen: Befehl zum Sichern und Wiederherstellen der MySQL-Datenbank
Memo zum Befehl zum Sichern und Wiederherstellen der MySQL-Datenbank
Das obige ist der detaillierte Inhalt vonAnalyse der Befehlsmethode der MySQL-Sicherungs- und Wiederherstellungsbibliothek (langer Artikel). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!