04-02-数据备份与还原

整库数据备份与还原

整库数据备份也叫做SQL数据备份:备份的结果是SQL指令。

MySQL中提供了一个专门用于备份SQL的客户端:mysqldump

在这里插入图片描述

应用场景

SQL备份是一种MySQL非常常见的备份与还原方式,SQL备份不只是备份数据,还备份对应的SQL指令(表结构):即便是数据库遭到毁灭性的破坏(数据库被删除),那么利用(SQL)备份依然可以实现数据还原。

SQL备份因为需要备份表结构,因此产生的备份文件特别大,因此不适合特大型数据备份,也不适合数据变换频繁型数据库备份。

应用方案

SQL备份

SQL备份用到的是专门的备份客户端,因此还没有与数据库进行连接

基本语法:mysqldump -hPup 数据库名字 [表1 [表2...]] > 备份文件地址

备份可以有三种形式

  1. 整库备份(只需要提供数据库名字)

    mysqldump -hlocalhost -P3306 -uroot -p12345678 mydatabase2 > /Users/lucky/Documents/dev/Java\ web/mysql/back.sql
    

    在这里插入图片描述

  2. 单表备份:数据库后面跟一张表

  3. 多表备份:数据库后面跟多张表

    mysqldump -hlocalhost -P3306 -uroot -p12345678 mydatabase2 my_student my_class > /Users/lucky/Documents/dev/Java\ web/mysql/back1.sql
    

    在这里插入图片描述

查看备份文件中的具体内容

在这里插入图片描述

数据还原

MySQL提供了多种方式来实现:

mysqldump备份的数据数据中没有关于数据库本身的操作,都是针对表级别的操作:当进行数据库还原时,必须指定数据库

  1. 利用mysql客户端:没有登录之前,可以直接用该客户端进行数据还原

    mysql -hPrp 数据库 < 备份文件

    create database mydb charset=utf8;
    use mydb;
    show tables;
    

    在这里插入图片描述

    mysql -hlocalhost -P3306 -uroot -p12345678 mydb < /Users/lucky/Documents/dev/Java\ web/mysql/back.sql
    

    在这里插入图片描述
    在这里插入图片描述

  2. SQL指令,提供了一种导入SQL指定的方式

    source 备份文件

  3. 人为操作:打开备份文件 复制所有SQL指令然后到mysql客户端去执行(不推荐)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值