• mysqldump备份mysql数据库


    如题

    准备数据

    创建一个数据库d1,表t1

    表结构如下

    mysql> desc t1;
    +-------+------------+------+-----+---------+----------------+
    | Field | Type       | Null | Key | Default | Extra          |
    +-------+------------+------+-----+---------+----------------+
    | xh    | int        | NO   | PRI | NULL    | auto_increment |
    | xm    | varchar(5) | YES  |     | NULL    |                |
    +-------+------------+------+-----+---------+----------------+
    2 rows in set (0.00 sec)

    插入数据后,内容如下:

    mysql> select * from t1;
    +----+------+
    | xh | xm   |
    +----+------+
    |  1 | zs   |
    |  2 | ls   |
    +----+------+
    2 rows in set (0.00 sec)

    备份

    mysqldump命令的大致用法:mysqldump -h 127.0.0.1 -u root -p666 xxx > f:数据库备份练习xxx.sql

    总的来说,用法跟进入mysql类似,其中-h后面接主机(本机可省略),xxx是数据库名,>后面跟备份文件名(也可以带路径)。

    注意是在操作系统命令行输入,不是在mysql里。

    操作如下

    [root@VM-4-9-centos ~]# mysqldump -u root -p d1 > d1.bak
    Enter password:
    [root@VM-4-9-centos ~]# ls
    d1.bak 

    还原

    要点:先建库,再还原。

    删除数据库

    mysql> drop database d1;
    Query OK, 1 row affected (0.03 sec)
    
    mysql> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | mysql              |
    | performance_schema |
    | sys                |
    +--------------------+
    4 rows in set (0.00 sec)

    还原

    [root@VM-4-9-centos ~]# mysql -u root -p d1 < d1.bak
    Enter password:

    查看还原效果

    mysql> use d1;
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -A
    
    Database changed
    mysql> desc t1;
    +-------+------------+------+-----+---------+----------------+
    | Field | Type       | Null | Key | Default | Extra          |
    +-------+------------+------+-----+---------+----------------+
    | xh    | int        | NO   | PRI | NULL    | auto_increment |
    | xm    | varchar(5) | YES  |     | NULL    |                |
    +-------+------------+------+-----+---------+----------------+
    2 rows in set (0.00 sec)
    
    mysql> select * from t1;
    +----+------+
    | xh | xm   |
    +----+------+
    |  1 | zs   |
    |  2 | ls   |
    +----+------+
    2 rows in set (0.00 sec)

     原理

    mysqldump 是 MySQL 自带的逻辑备份工具。它的备份原理是连接到 MySQL 数据库,将需要备份的数据查询出来,将查询出的数据转换成对应的sql语句,当我们需要还原这些数据时,只要执行这些sql语句,如insert,即可将对应的数据还原。

    其他数据库备份,也尽量使用这种原理。在跨版本的时候尤其有优势。

  • 相关阅读:
    最全的静态网站生成器(开源项目)
    移动互联网流量变现模式调研问卷
    公众平台商户接入(微信支付)功能申请教程
    微信支付全面开放
    百度天气预报接口
    微信公众平台开发(83) 生成带参数二维码
    微信支付接口申请指南
    微信自媒体账号涉违规大规模被封
    php大文件上传解决方案支持分片断点上传
    html5大文件上传解决方案(500M以上)
  • 原文地址:https://www.cnblogs.com/wanjinliu/p/15390195.html
Copyright © 2020-2023  润新知