首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 还原单个库

基础概念

MySQL 是一个关系型数据库管理系统,广泛用于存储和管理数据。还原单个库是指将数据库从备份文件恢复到某个特定时间点的状态。

相关优势

  1. 数据保护:备份和还原机制可以防止数据丢失,确保数据的安全性。
  2. 灾难恢复:在发生灾难性事件时,可以快速恢复数据,减少业务中断时间。
  3. 版本控制:通过备份,可以轻松回滚到之前的数据库版本。

类型

  1. 物理备份:备份数据库的物理文件(如 .frm.ibd 文件)。
  2. 逻辑备份:备份数据库的逻辑结构(如表结构和数据),通常使用 mysqldump 工具。
  3. 增量备份:基于上次全量备份,只备份自上次备份以来发生变化的数据。

应用场景

  1. 数据恢复:当数据库发生故障或数据损坏时,可以通过备份还原数据。
  2. 版本回滚:在发布新功能或更新后,如果出现问题,可以快速回滚到之前的稳定版本。
  3. 迁移数据:在不同环境(开发、测试、生产)之间迁移数据。

还原单个库的步骤

假设我们有一个名为 mydatabase 的数据库,并且已经通过 mysqldump 工具创建了一个备份文件 mydatabase_backup.sql

使用 mysqldump 还原

  1. 登录 MySQL 数据库
  2. 登录 MySQL 数据库
  3. 选择数据库
  4. 选择数据库
  5. 还原备份文件
  6. 还原备份文件

使用 mysql 命令还原

  1. 登录 MySQL 数据库
  2. 登录 MySQL 数据库

常见问题及解决方法

问题:还原时出现 ERROR 2006 (HY000): MySQL server has gone away

原因:备份文件过大,导致 MySQL 服务器在处理过程中断开连接。

解决方法

  1. 增加 max_allowed_packet 参数的值:
  2. 增加 max_allowed_packet 参数的值:
  3. 分块还原备份文件:
  4. 分块还原备份文件:

问题:还原时出现 ERROR 1046 (3D000): No database selected

原因:在执行 SOURCE 命令时没有选择目标数据库。

解决方法: 确保在执行 SOURCE 命令之前已经选择了目标数据库:

代码语言:txt
复制
USE mydatabase;
SOURCE /path/to/mydatabase_backup.sql;

参考链接

通过以上步骤和方法,可以有效地还原 MySQL 中的单个数据库,并解决常见的还原问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL通过 XtraBackup 备份恢复单个库

1.概述 本文通过 XtraBackup 备份单个数据库,然后恢复到另一个实例,用于快速迁移大数据量,使用的软件版本为: 软件名 版本 MySQL mysql-5.7.39-linux-glibc2.12...4.备份 MySQL-A sysbench 库的表结构 shell> /mysql/svr/mysql/bin/mysqldump -ugreatsql -pgreatsql -h127.0.0.1 -...sbtest9.frm 可以看到ibd文件已被丢弃 9.prepare 备份文件 注意这里需要加 --export 选项,它允许导出单个表以进行导入到另一个服务器 shell> innobackupex...| 10000 | +----------+ 1 row in set (0.04 sec) 总结 通过上述方法可以快速备份恢复大数据量的库,也可以同时指定多个库,单张表或多张表进行恢复。...---- 关于 GreatSQL GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。

2.2K61
  • Mysql数据库备份和还原

    备份MySQL数据库的命令 mysqldump-hhostname-uusername-ppassworddatabasename>backupfile.sql 备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库...|gzip>backupfile.sql.gz 备份MySQL数据库某个(些)表 mysqldump-hhostname-uusername-ppassworddatabasenamespecific_table1specific_table2...>backupfile.sql 同时备份多个MySQL数据库 mysqldump-hhostname-uusername-ppassword–databasesdatabasename1databasename2databasename3...备份服务器上所有数据库 mysqldump–all-databases>allbackupfile.sql 还原MySQL数据库的命令 mysql-hhostname-uusername-ppassworddatabasename...<backupfile.sql 还原压缩的MySQL数据库 gunzipmysql-uusername-ppassworddatabasename 将数据库转移到新服务器

    4.2K20

    Mysql数据库备份与还原

    Mysql数据库备份与还原 1. 备份的应用场景 在服务器进行数据传输、数据存储和数据交换,就有可能产生数据故障。比如发生意外停机或存储介质损坏。...还原 要先登录 create database db1; use db1; source 路径/备份.sql; 执行这个sql脚本文件 “注意:还原的时候需要先登录MySQL,并选中对应的数据库...备份、还原db1数据库中的数据 4.1 备份 db1 数据库 [root@server01 opt]# mysqldump -uroot -p -h127.0.0.1 -P3306 db1 > db1....; -- 查看数据库中的表,当前没有表 Empty set (0.00 sec) mysql> 1590461051865 4.5 使用SOURCE命令还原数据 -- 使用 source 命令导入数据...> 5. mysql 命令导入数据 在上面我们使用 source 命令来还原数据,但是这个缺陷是要先进行 mysql 登录。

    1.8K20

    MySQL数据库备份与还原

    1.基本命令 1.1 登录mysql: -u:指定登录账户 -h:指定mysql服务器ip -P:指定端口(默认值为0) -p:指定密码(密码需紧跟在-p后面,中间不能有空格) -D:指定要使用的数据库...demo 1.2 查看mysql版本: 未登录mysql状态下查询: mysql --version 已登录mysql状态下查询: select version(); 1.3 查看所有数据库: show...2.5 使用示例: 备份hostpital数据库到文件hostpital.sql,mysql登录信息:ip为127.0.0.1,端口为3306,用户名为root,密码为root。...mysqldump -uroot -h 127.0.0.1 -P 3306 -proot hostpital > hostpital.sql 3.恢复 3.1 未登录mysql状态下还原: -u:指定登录账户...-h:指定mysql服务器ip -P:指定端口(默认值为0) -p:指定密码(密码需跟在-p后面,中间不能有空格) -v:打印有关各个阶段的信息 -D:指定要恢复到数据库名字 mysql -uroot

    3.8K30

    MySQL数据库备份与还原

    通常:备份数据库名_back.sql 还原备份的文件数据:首先需要进入到mysql环境–>创建-个库–>在库下还原 –>source 备份的数据库脚本 例子: 备份: 在命令行输入: mysql...-uroot -proot 16jike2_account>D:16jike2_account_back.sql 系统提示在命令行输入密码可能不安全,可以改用一下命令行: mysql -uroot...在D盘的根目录,我们可以看到备份文件已创建 打开16jike2_account_back.sql备份文件,可以看到备份数据库的一些创建语句和插入数据: 还原: 避免还原数据库与已存在的数据库重名,我们先查看一下已存在的数据库用..._account; 查看一下当前使用的数据库: select database(); 开始还原,使用一下命令: source D:16jike2_account_back.sql; 查看是恢复成功,先查看数据表是否恢复...还原备份的文件数据:文件–>打开–>选择备份文件(.sql)–>crtl+A选中文件中所有内容–>执行 恢复备份完成 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    3.9K40

    mysql数据库备份和还原的命令_Mysql数据库备份和还原常用的命令

    Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下面就是操作的常用命令...一、备份命令 1、备份MySQL数据库的命令 mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql 2、备份MySQL...数据库为带删除表的格式 备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。...> structurebackupfile.sql 7、备份服务器上所有数据库 mysqldump –all-databases > allbackupfile.sql 二、还原命令 1、还原MySQL...数据库的命令 mysql -hhostname -uusername -ppassword databasename < backupfile.sql 2、还原压缩的MySQL数据库 gunzip <

    7.5K10

    MySQL_数据库备份与还原

    数据库备份 备份命令在shell命令行进行 $ mysqldump [-P端口号] -u用户名 -p密码 [-B] 数据库名 > 备份后的名称.bak.sql [ ]内的是可以省略的 -u和用户名、-p...mysqldump [-P端口号] -u用户名 -p密码 [-B] 数据库1 数据库2 > 备份后的名称.bak.sql eg:mysqldump -uroot -p0295 -B test2 test_mysql...> test.back.sql两个数据库备份到了一个备份文件上 也可以只进行数据库中表的备份 $ mysqldump [-P端口号] -u用户名 -p密码 数据库名 表1 表2 > 备份后的名称.bak.sql...》 本文为https://blog.musnow.top/posts/2109090510/的总结与补充其他知识点详见置顶链接 还原命令在mysql中执行 mysql> source 备份文件路径 eg...:source /yj/test2.bak.sql 数据库中的内容和原来数据库中的内容是相同的 mysql备份的时候,会将里面的语句智能化简

    11010

    浅谈MySQL数据库的备份与还原

    欢迎转载,转载请注明出处,谢谢 之前用过很长时间的Oracle 11gR2,数据还原备份这种操作经常遇到,操作起来略显蛋疼,几乎都要有阴影了。...今天体验了一下MySQL的备份与还原,感觉简单多了,分享一下。 一、备份 MySQL的备份我是用mysqldump,这玩意操作及其简单,第一次是用就爱上了。...dbname是需要备份的数据库名,可以使用show databases命令来查看所有数据库的名称。table1是备份数据库下面的表名,可以跟多个表名。...[root@Geeklp-MySQL ~] # mysqldump -u root -p reafdb >/backup/reafdb.sql Enter password: 二、还原 还原过程也是很简单的...使用mysqldump命令备份的数据库的语法如下: mysql -u root -p [dbname] < backup.sql 实际操作: [root@Geeklp-MySQL ~]# mysql

    2.2K10

    浅谈MySQL数据库的备份与还原

    之前用过很长时间的Oracle 11gR2,数据还原备份这种操作经常遇到,操作起来略显蛋疼,几乎都要有阴影了。今天体验了一下MySQL的备份与还原,感觉简单多了,分享一下。...一、备份 MySQL的备份我是用mysqldump,这玩意操作及其简单,第一次是用就爱上了。...dbname是需要备份的数据库名,可以使用show databases命令来查看所有数据库的名称。table1是备份数据库下面的表名,可以跟多个表名。...[root@Geeklp-MySQL ~] # mysqldump -u root -p reafdb >/backup/reafdb.sql Enter password: 二、还原 还原过程也是很简单的...使用mysqldump命令备份的数据库的语法如下: mysql -u root -p [dbname] 实际操作: [root@Geeklp-MySQL ~]# mysql -u root -p reafdb

    2.6K90

    MySQL 数据库备份和还原数据库 mysqldump、source

    备份数据库或指定的表 ---- 备份指定的数据库,默认包含表数据 mysqldump -u用户名 -p[密码] 库名 > 文件路径 导出指定数据库中的所有表的结构,不要表中的数据 -d 是否只导出表结构...,有该参数代表只导出表结构 mysqldump -u用户名 -p[密码] -d 库名 > 文件路径 备份某个表 -- 导出表结构和表中的数据 mysqldump -u用户名 -p[密码] 库名 表名 >...数据库恢复命令 ---- 方法一:使用 mysqldump 命令还原数据,但我测试的不行,既没有报错,也没有导入成功,在学校时用过记得是可以的 mysqldump -u用户名 -p密码 库名 库,直接导入 3....Navicat 的备份和还原应该的大伙用的多的 ----

    3.5K20

    mysql还原数据mysqldump

    mysqldump命令导入数据库 目录 mysqldump命令导入数据库 还原数据库(推荐背下来) 实例: 1.查看是否有同名数据库 2.删除【mytest】数据库【drop database mytest...;】 3.退出数据库【quit】 4.创建数据库【create database mytest;】与使用数据库【use mytest;】 5.导入【D:\data\script.sql】备份的脚本文件...6.数据校验 还原数据库(推荐背下来) 语法: source 盘符:\路径\文件名.sql; 案例(还原数据库):【sql脚本文件保存在D:\data\script.sql】 source D:\data...\script.sql 实例: 1.查看是否有同名数据库 2.删除【mytest】数据库【drop database mytest;】 3.退出数据库【quit】 4.创建数据库【create database...mytest;】与使用数据库【use mytest;】 5.导入【D:\data\script.sql】备份的脚本文件 6.数据校验 查看数据表【show tables;】 查看数据【select

    3.2K10

    备份和还原MySQL数据库的简便方法

    我们现在将讨论如何备份数据库和还原MySQL。数据库的维护非常重要,因为数据库包含我们拥有的重要数据,因此,应备份数据库以避免数据丢失。 备份有两个目的。...如何备份数据库和还原MySQL 备份和还原MySQL数据库的步骤如下: 如何使用CLI备份数据库 使用MySQL提供的mysqldump工具,备份或导出MySQL数据库非常容易。...如何使用CLI还原数据库 恢复或导入我们先前备份的MySQL数据库文件的另一种方法是使用mysql就像备份或导出数据库一样简单。...- 是要还原或导入的数据库的名称; [backupfile] - 是还原文件的名称。...mysql -hhostname -uusername -ppassword databasename < backupfile.sql 还原压缩的MySQL数据库 gunzip < backupfile.sql.gz

    2.9K10

    用Java代码备份和还原MySQL数据库

    IOException{ Runtime runtime = Runtime.getRuntime(); //-u后面是用户名,-p是密码-p后面最好不要有空格,-family是数据库的名字...IOException{ Runtime runtime = Runtime.getRuntime(); //-u后面是用户名,-p是密码-p后面最好不要有空格,-family是数据库的名字...//我就是因为这句话没加导致程序运行成功,但是数据库里面的内容还是以前的内容,最好写上完成的sql放到cmd中一运行才知道报错了 //错误信息: //mysql...set utf-8 (path: C:\Program Files\MySQL\MySQL Server 5.5\share\charsets), //又是讨人厌的编码问题,在恢复的时候设置一下默认的编码就可以了...Process process = runtime.exec("mysql -u root -p123456 --default-character-set=utf8 family");

    3.6K00

    xtrabackup 备份还原mysql

    创建备份目录: mkdir -pv /devbdata//mysql_backup/xbstream_no_month_tables/full 数据库数据准备 ###### mysql 创建库,并生成...,单个库时可省略) –tables 表列表(单个表时可省略) ①同时导出结构以及数据时可同时省略-d和-t ②同时 不 导出结构和数据可使用-ntd ③只导出存储过程和函数可使用-R -ntd ④导出所有...> 三、数据恢复 先还原表结构 mysql -uroot -p'P@SSw0rdnqt123' -h 127.0.0.1 mysql> source /devbdata/mysql_backup/tdata.sql..._$format_time # 新数据库的存储 路径 datadir=/devbdata/.data/mysql #MySQL数据库用户名 MyUSER=root #MySQL数据库密码 MyPASS=...P@SSw0rdnqt123 #ip地址 MyHOST=localhost #MySQL数据库端口号 PORT=3306 #恢复数据库名,一次只能恢复一个库,需要手动修改这个库名 # `tdata` `

    34310
    领券