zoukankan      html  css  js  c++  java
  • Mysqldump备份和恢复

    使用Mysqldump命令备份和恢复Mysql数据库
    之前一直习惯用phpmyadmin备份恢复数据库,不过数据库文件大了用phpmyadmin就不行了。这时候我们就需要Mysqldump来备份和恢复。
    以下内容来自网络。

    1、导出
    命令:mysqldump -u用户名 -p数据库密码 数据库名 > 文件名

    如果用户名需要密码,则需要在此命令执行后输入一次密码核对;如果数据库用户名不需要密码,则不要加“-p”参数,导入的时候相同。
    注意输入的用户名需要拥有对应数据库的操作权限,否则无法导出数据。由于是作系统维护和全部数据库的导出,一般我们使用root等超
    级用户权限。

    比如要将abc这个数据库导出为一个文件名为db_abc.sql的数据库文件到当前目录下,则输入下面的命令:

    mysqldump -uroot -ppassword abc >db_abc.sql
    

    如果要直接导出sql.zip或者gzip格式文件命令如下:

    mysqldump -uroot -ppassword abc >gzip > db_abc.sql.gzip
    

    需要注意的是:-u和-p后面直接跟用户名和密码,不要有空格。

    2、导入
    命令:mysql -u用户名 -p数据库密码 数据库名 < 文件名 同mysqldump命令一样的用法,各参数的意义同mysqldump。
    比如我们要将/root/backup/db_abc.sql这个文件的数据导入到abc数据库中,则使用下面的命令:

    mysql -uroot -ppassword abc < /root/backup/db_abc.sql
    

    如果是zip或gzip格式则使用下面的命令:

    mysql -uroot -ppassword abc <gzip </root/backup/abc.sql.gzip
    

    3、其他命令参考

    备份远程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 < backupfile.sql
    

    还原压缩的MySQL数据库

    gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
    

    将数据库转移到新服务器

    1、首先在新的服务器上创建数据库,create database newdatabase;
    2、mysqldump -uusername -ppassword olddatabasename | mysql -hhostname -uuserbname –ppassword newdatabasename

    4、总结一下压缩备份
    备份并用gzip压缩:mysqldump < mysqldump options> | gzip > outputfile.sql.gz
    从gzip备份恢复:gunzip < outputfile.sql.gz | mysql < mysql options>
    备份并用bzip压缩:mysqldump < mysqldump options> | bzip2 > outputfile.sql.bz2
    从bzip2备份恢复:bunzip2 < outputfile.sql.bz2 | mysql < mysql options>


    1.导出整个数据库

    mysqldump -u用户名 -p密码 数据库名 > 导出的文件名
    C:Usersjack> mysqldump -uroot -pmysql sva_rec > e:sva_rec.sql

    2.导出一个表,包括表结构和数据

    mysqldump -u用户名 -p 密码 数据库名 表名> 导出的文件名
    C:Usersjack> mysqldump -uroot -pmysql sva_rec date_rec_drv> e:date_rec_drv.sql

    3.导出一个数据库结构

    C:Usersjack> mysqldump -uroot -pmysql -d sva_rec > e:sva_rec.sql

    4.导出一个表,只有表结构

    mysqldump -u用户名 -p 密码 -d数据库名 表名> 导出的文件名
    C:Usersjack> mysqldump -uroot -pmysql -d sva_rec date_rec_drv> e:date_rec_drv.sql

    5.导出多个库

    mysqldump -uroot -pmysql --databases db1 db2 db3>D: emp.sql

    只要数据结构:

    mysqldump -uroot -pmysql --no-data --databases db1 db2 db3>D: emp.sql

    ps: 导出数据带change master to参数: --master-data=1

    5.导入数据库

    常用source 命令
    进入mysql数据库控制台,
    如mysql -u root -p
    mysql>use 数据库
    然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
    mysql>source d:wcnc_db.sql

    ======================================================================================

    MySQLdump是MySQL自带的导出数据工具,通常我们用它来导出MySQL中,但是有时候我们需要导出MySQL数据库中某个表的部分数据,这时该怎么办呢?

    mysqldump命令中带有一个 --where/-w 参数,它用来设定数据导出的条件,使用方式和SQL查询命令中中的where基本上相同,有了它,我们就可以从数据库中导出你需要的那部分数据了。

    命令格式如下:

    mysqldump -u用户名 -p密码 数据库名 表名 --where="筛选条件" > 导出文件路径

    例子:

    从meteo数据库的sdata表中导出sensorid=11 且 fieldid=0的数据到 /home/xyx/Temp.sql 这个文件中

    mysqldump -uroot -p123456 meteo sdata --where=" sensorid=11 and fieldid=0" > /home/xyx/Temp.sql

    另外你还可以直接导出 文本文件*.txt

    mysqldump -uroot -p123456 meteo sdata --where=" sensorid=11 and fieldid=0" > /home/xyx/Temp.txt

    ////////////////////////////////////////////////////////////////////////////////////////////////

    以下是 mysqldump 的一些使用参数

    备份数据库
    #mysqldump 数据库名 >数据库备份名

    #mysqldump -A -u用户名 -p密码 数据库名>数据库备份名

    #mysqldump -d -A --add-drop-table -uroot -p >xxx.sql

    1.导出结构不导出数据

    mysqldump -d 数据库名 -uroot -p > xxx.sql

    2.导出数据不导出结构

    mysqldump -t 数据库名 -uroot -p > xxx.sql

    3.导出数据和表结构

    mysqldump 数据库名 -uroot -p > xxx.sql

    4.导出特定表的结构

    mysqldump -uroot -p -B数据库名 --table 表名 > xxx.sql

    #mysqldump [OPTIONS] database [tables]

    mysqldump支持下列选项:

    --add-locks
    在每个表导出之前增加LOCK TABLES并且之后UNLOCK TABLE。(为了使得更快地插入到MySQL)。
    --add-drop-table
    在每个create语句之前增加一个drop table。
    --allow-keywords
    允许创建是关键词的列名字。这由表名前缀于每个列名做到。
    -c, --complete-insert
    使用完整的insert语句(用列名字)。
    -C, --compress
    如果客户和服务器均支持压缩,压缩两者间所有的信息。
    --delayed
    用INSERT DELAYED命令插入行。
    -e, --extended-insert
    使用全新多行INSERT语法。(给出更紧缩并且更快的插入语句)
    -#, --debug[=option_string]
    跟踪程序的使用(为了调试)。
    --help
    显示一条帮助消息并且退出。
    --fields-terminated-by=...
     
    --fields-enclosed-by=...
     
    --fields-optionally-enclosed-by=...
     
    --fields-escaped-by=...
     
    --fields-terminated-by=...
    这些选择与-T选择一起使用,并且有相应的LOAD DATA INFILE子句相同的含义。
    LOAD DATA INFILE语法。
    -F, --flush-logs
    在开始导出前,洗掉在MySQL服务器中的日志文件。
    -f, --force,
    即使我们在一个表导出期间得到一个SQL错误,继续。
    -h, --host=..
    从命名的主机上的MySQL服务器导出数据。缺省主机是localhost。
    -l, --lock-tables.
    为开始导出锁定所有表。
    -t, --no-create-info
    不写入表创建信息(CREATE TABLE语句)
    -d, --no-data
    不写入表的任何行信息。如果你只想得到一个表的结构的导出,这是很有用的!
    --opt
    同--quick --add-drop-table --add-locks --extended-insert --lock-tables。
    应该给你为读入一个MySQL服务器的尽可能最快的导出。
    -pyour_pass, --password[=your_pass]
    与服务器连接时使用的口令。如果你不指定“=your_pass”部分,mysqldump需要来自终端的口令。
    -P port_num, --port=port_num
    与一台主机连接时使用的TCP/IP端口号。(这用于连接到localhost以外的主机,因为它使用 Unix套接字。)
    -q, --quick
    不缓冲查询,直接导出至stdout;使用mysql_use_result()做它。
    -S /path/to/socket, --socket=/path/to/socket
    与localhost连接时(它是缺省主机)使用的套接字文件。
    -T, --tab=path-to-some-directory
    对于每个给定的表,创建一个table_name.sql文件,它包含SQL CREATE 命令,和一个table_name.txt文件,它包含数据。注意:这只有在mysqldump运行在mysqld守护进程运行的同一台机器上的时候才工作。.txt文件的格式根据--fields-xxx和 --lines--xxx选项来定。
    -u user_name, --user=user_name
    与服务器连接时,MySQL使用的用户名。缺省值是你的Unix登录名。
    -O var=option, --set-variable var=option设置一个变量的值。可能的变量被列在下面。
    -v, --verbose
    冗长模式。打印出程序所做的更多的信息。
    -V, --version
    打印版本信息并且退出。
    -w, --where='where-condition'
    只导出被选择了的记录;注意引号是强制的!
    "--where=user='jimf'" "-wuserid>1" "-wuserid<1"

    导入数据:

    由于mysqldump导出的是完整的SQL语句,所以用mysql客户程序很容易就能把数据导入了:

    #mysql 数据库名 < 文件名

    or:

    #show databases;

    然后选择被导入的数据库:

    #use ***;

    #source /tmp/xxx.sql

    ////////////////////////////////////////////////////////////////////////////////////////////////////

    mysqldump局部数据导出的limit使用:

    mysqldump -uuser -p dbname tablename --where '1=1 limit 5' | gzip > /home/usr/usr/test.sql

    防止出现乱码,导入导出前用--default-character-set=utf8规范连接

    另:

    使用mysql -e参数导出数据

    mysql -uroot -p -e 'select * from foo' > /tmp/datafile

    再配合mysql load data infile导入数据

    导出前锁全表:

    FLUSH TABLES WITH READ LOCK;

    解锁:

    UNLOCK TABLES;

  • 相关阅读:
    Windows 配置 allure report 环境
    ruby 异常处理 begin rescue end
    ruby 安装 mysql2 命令
    Linux 新建文件/文件夹,删除文件文件夹,查找文件 打开文件
    Ubuntu 共享 转载
    单元测试框架 unittest 的运行方法if __name__ == '__main__': unittest.main()
    Python 字典和json的本质区别(个人理解)

    接口自动化大致流程。
    iOS开发UI篇—CAlayer(自定义layer)
  • 原文地址:https://www.cnblogs.com/nxzblogs/p/12587231.html
Copyright © 2011-2022 走看看