MySQL中mysqldum数据库的备份和恢复
在mysql中自带了 mysqldum命令可直接能数据库进行备份和恢复操作,下面我来详细的介绍关于MySQL中mysqldum命令的用法。
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 |
打开开始->运行->输入cmd进入命令行模式
代码如下 | 复制代码 |
c:>mysqldump -h localhost -u root -p mydb >e:mysqlmydb.sql |
然后输入密码,等待一会导出就成功了,可以到目标文件中检查是否成功。
2.将数据库mydb中的mytable导出到e:mysqlmytable.sql文件中:
代码如下 | 复制代码 |
c:>mysqldump -h localhost -u root -p mydb mytable >e:mysqlmytable.sql |
3.将数据库mydb的结构导出到e:mysqlmydb_stru.sql文件中:
代码如下 | 复制代码 |
c:>mysqldump -h localhost -u root -p mydb --add-drop-table >e:mysqlmydb_stru.sql |
//-h localhost可以省略,其一般在虚拟主机上用
1.2 还原
用 mysqldump 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
从外部文件导入数据到数据库:
例如:
代码如下 | 复制代码 |
/usr/local/mysql/bin/mysql -uyejr -pyejr db_name |
从e:mysqlmydb2.sql中将文件中的SQL语句导入数据库中:
代码如下 | 复制代码 |
c:>mysql -h localhost -u root -p mydb2 |
•用 SOURCE 语法
其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:
代码如下 | 复制代码 |
SOURCE /tmp/db_name.sql; |
这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。
进入mysql数据库控制台 : 如 mysql -u root -p
代码如下 | 复制代码 |
mysql>use databasename |
然后使用source命令,后面参数为脚本文件(这里用到的是.sql)
代码如下 | 复制代码 |
mysql>source d:mydb.sql |
然后输入密码,就OK了
二.命令行进入MYSQL的方法:
代码如下 | 复制代码 |
C:>mysql -h hostname -u username -p |
按ENTER键,等待然后输入密码,这里hostname为服务器的名称,如localhost,username为MYSQL的用户名,如root.进入命令行就可以直接操作MYSQL了。
关于导入文件大小限制问题的解决:
默认情况下:mysql对导入的文件大小有限制的,最大为2M,所以当文件很大时,直接无法导入,解决列举如下:
1.在php.ini中修改相关参数:
影响Mysql导入文件大小的参数有三个:
代码如下 | 复制代码 |
memory_limit=128M, upload_max_filesize=2M, post_max_size=8M |
修改upload_max_filesize=200M这里修改满足你需要的大小,可以同时修改其他两项memory_limit=250M ,post_max_size=200M.这样就可以导入200M以下的.sql文件了。
上文是把mysql放置在系统路径下,其实不放也可以。如我的mysql安装目录为D:MySQL Server 5.0;则首先打开dos窗口,然后输入D:(没有'')回车;此时应该会出现D:>这样的标志,然后在其后输入D:MySQL Server 5.0bin回车;出现D:MySQL Server 5.0bin>接着输入mysqldump -u root -p 数据库名 >数据库名.sql(也可以输入路径); (具体参照上面)导入文件同样,只是改了'>'为'

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

De nombreux amis ne savent pas comment récupérer les données diskgenius, c'est pourquoi l'éditeur partagera les didacticiels pertinents sur la récupération de données diskgenius. Je pense que cela sera utile à tout le monde. Tout d'abord, dans le diagramme de partition du disque dur au-dessus de l'interface principale de DiskGenius, vous pouvez directement sélectionner la partition cible et cliquer avec le bouton droit. Ensuite, dans le menu contextuel qui apparaît, recherchez et cliquez sur l'élément de menu « Récupération de fichiers supprimés ou formatés », comme indiqué sur la figure. Dans la deuxième étape, la fenêtre des options de récupération apparaît et assurez-vous de cocher les trois options « Récupérer les fichiers supprimés », « Récupération complète » et « Analyse supplémentaire des types de fichiers connus ». Étape 3 : Cliquez sur le bouton « Sélectionner le type de fichier » à droite et spécifiez les fichiers que vous devez récupérer dans la fenêtre contextuelle

Solution au problème de perte de paramètres PHP Dans le processus de développement de programmes PHP, nous rencontrons souvent le problème de perte de paramètres. Cela peut être dû à des paramètres incomplets transmis par le front-end, à une manière incorrecte de recevoir les paramètres par le back-end, etc. Dans cet article, nous fournirons quelques solutions au problème des paramètres manquants en PHP, ainsi que des exemples de code spécifiques. 1. Problème de transmission des paramètres front-end Utilisez la méthode GET pour transmettre des paramètres Lorsque vous utilisez la méthode GET pour transmettre des paramètres, les paramètres seront ajoutés à l'URL demandée sous la forme de paramètres d'URL. Lors de la réception des paramètres dans le backend

Sauvegarde et récupération de données ThinkPHP6 : assurer la sécurité des données Avec le développement rapide d'Internet, les données sont devenues un atout extrêmement important. La sécurité des données est donc une préoccupation majeure. Dans le développement d’applications Web, la sauvegarde et la récupération des données constituent un élément important pour garantir la sécurité des données. Dans cet article, nous présenterons comment utiliser le framework ThinkPHP6 pour la sauvegarde et la récupération des données afin de garantir la sécurité des données. 1. Sauvegarde des données La sauvegarde des données fait référence à la copie ou au stockage des données dans la base de données d'une manière ou d'une autre. De cette façon, même si les données

Sauvegarde des données et restauration des applications PHP via DockerCompose, Nginx et MariaDB Avec le développement rapide de la technologie de cloud computing et de conteneurisation, de plus en plus d'applications choisissent d'utiliser Docker pour se déployer et s'exécuter. Dans l'écosystème Docker, DockerCompose est un outil très populaire capable de définir et de gérer plusieurs conteneurs via un seul fichier de configuration. Cet article explique comment utiliser DockerCompose, Ng

Laravel est un framework d'application Web PHP populaire qui offre de nombreux moyens rapides et simples de créer des applications Web efficaces, sécurisées et évolutives. Lors du développement d'applications Laravel, nous devons souvent considérer la question de la récupération des données, c'est-à-dire comment récupérer les données et assurer le fonctionnement normal de l'application en cas de perte ou de dommage de données. Dans cet article, nous présenterons comment utiliser le middleware Laravel pour implémenter des fonctions de récupération de données et fournirons des exemples de code spécifiques. 1. Qu'est-ce que Lara ?

Comment résoudre un secteur de disque dur cassé ? Un secteur de disque dur cassé est une panne matérielle courante, qui peut entraîner une perte de données et affecter les performances de l'ordinateur. Il est très important de comprendre et de résoudre le problème des secteurs défectueux du disque dur. Cet article présentera le concept de secteurs de disque dur, discutera des causes courantes des secteurs de disque dur défectueux et des solutions. 1. Que sont les secteurs du disque dur ? Avant de présenter comment résoudre le problème des secteurs de disque dur défectueux, commençons par comprendre ce que sont les secteurs de disque dur. Un secteur de disque dur est la plus petite unité lisible et inscriptible sur un disque dur. C'est une petite section d'espace sur un disque dur.

Comment résoudre le problème de cohérence de la sauvegarde des données dans le développement du Big Data C++ ? Dans le développement du Big Data C++, la sauvegarde des données est un élément très important. Afin de garantir la cohérence de la sauvegarde des données, nous devons prendre une série de mesures pour résoudre ce problème. Cet article explique comment gérer les problèmes de cohérence de la sauvegarde des données dans le développement du Big Data C++ et fournit des exemples de code correspondants. Utiliser des transactions pour la sauvegarde des données Les transactions sont un mécanisme permettant de garantir la cohérence des opérations sur les données. En C++, nous pouvons utiliser le concept de transaction dans la base de données pour implémenter la sauvegarde des données.

Comment récupérer rapidement des pannes et des erreurs rencontrées par la base de données MySQL ? MySQL est un système de gestion de bases de données relationnelles open source largement utilisé sur lequel de nombreuses applications et sites Web s'appuient pour stocker et gérer des données. Cependant, les pannes et les erreurs de base de données sont inévitables, ce qui peut entraîner une perte de données ou un dysfonctionnement des applications. Lorsque vous rencontrez une panne ou une erreur de base de données MySQL, il est très important de récupérer la base de données rapidement et efficacement. Cet article présentera quelques méthodes pour restaurer rapidement la base de données MySQL. Déterminez le type de défaut et d’erreur avant de démarrer
