首页 数据库 mysql教程 Mysql入门系列:使用MYSQL备份数据恢复_MySQL

Mysql入门系列:使用MYSQL备份数据恢复_MySQL

Jun 01, 2016 pm 01:55 PM
数据恢复

  数据库毁坏发生的原因有许多,且程度各不相同。如果幸运的话,可能是一两个表的小毁坏(例如,如果您的机器由于断电而暂时停机)。如果不是这样,可能需要置换整个的数据目录(例如,如果某个磁盘瘫痪而且数据目录在它上)。在其他情况下也需要恢复操作,例如,当用户错误地删除数据库或表时,或者错误地删除表的内容时。不论这些不幸的事件发生是由于什么原因,都需要恢复它们。

  如果表被毁坏但没有丢失,可试着用myisamchk 或isamchk 来修复它们。如果修复实用程序能修复它们,就根本没有必要使用备份文件。表的修复过程将在第13 章讨论。如果表被丢失或不能修复,则需要恢复它们。

  恢复过程包括两个信息源:备份文件和更新日志。备份文件将表恢复到进行该备份时的状态。但是,在备份和故障发生这段时间中,表通常已经被修改。更新日志包含了用来完成这些修改的查询。可以通过将更新日志作为对mysql的输入来重复这些查询(这就是为什么

  应该允许更新日志的原因。如果您还没有使更新日志有效,现在赶快做,并在进一步读取之前生成一个新的备份)。

  恢复过程根据必须恢复的信息的多少而变化。事实上,恢复整个数据库比恢复单个的表要容易,因为对数据库应用更新日志比对表要容易。

  恢复整个数据库

  首先,如果要恢复的数据库是含有授权表的mysql数据库,将需要使用- - s k i p - g r a n t - tables选项运行服务器。否则,服务器将抱怨无法找到授权表。在恢复表之后,执行mysqla d m i n flush-privileges 来告诉服务器加载授权表,并用它们启动。

  将原数据库目录的内容拷贝到其他的地方。例如,您可能会在稍后用它们进行崩溃表的事后分析检查(post-mortem examination)。

  用最新的备份文件重新加载数据库。如果您打算使用由mysqldump 加载的文件,则需要将它们作为mysql的输入。如果打算使用从数据库中直接拷贝的文件(如,用tar 或c p),则将它们直接拷贝回到该数据库目录中。但是,在这种情况下,应该在拷贝这些文件之前关闭服务器,然后再重新启动它。

  用更新日志重做在进行备份后又修改了数据库表的查询。对于所有可用的更新日志,可使用它作为mysql的输入。指定--one-database 选项,使mysql只对想要恢复的数据库执行查询。如果您知道需要使用所有的更新日志文件,可在包含日志的目录中使用

  下列命令:

  % ls -t -r -l update.(0-9)* | xargs cat | mysql--one-database db_name

  ls 命令产生更新日志文件的单列列表,更新日志文件根据服务器生成的顺序进行排序(要知道,如果您修改了其中的任何文件,排序的顺序都将改变,这将导致更新日志按错误的顺序使用)。

  您很可能必须使用某些更新日志。例如,如果自备份以来所产生的日志命名为up date . 3 9 2、update.393 等等,可以重新运行它们中的命令:

  % mysql--one-database db_name < updata.392

  % mysql--one-database db_name < updata.393

  。。。

  如果正在运行恢复并打算使用更新日志恢复由于失策的DROP DATA B A S E、D R O P TABLE 或DELETE 语句而丢失的信息,应确保先从更新日志中删除这些语句。

  恢复单个的表

  恢复单个表是很困难的。如果有通过mysqldump 生成的备份文件并且它恰好不包含您想要的表数据,则需要抽取相关的行并用它们作为mysql的输入,这部分较容易。困难的是抽取应用于该表的更新日志的片段。您会发现: mysql_find_rows 实用程序对这方面有帮助,它可以从更新日志中抽取多行查询。

  另一种可能性是用另一个服务器恢复整个数据库,然后将所要的该表的文件拷贝到原始数据库中。这实际很容易!在将文件拷贝回数据库目录时,应确保原始数据库的服务器关闭。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

windows7系统注册表文件遗失或损坏怎么办 windows7系统注册表文件遗失或损坏怎么办 Jul 08, 2023 pm 05:29 PM

windows7用户在启动时遇到了系统注册表文件遗失或损坏的现象,像这种情况要怎么解决呢?你先强制重启电脑,以后按F8键,在打开的页面中选择安全模式进到,之后在菜单栏找到命令提示符开启,输入SFC/SCANNOW指令并回车实行,这时候系统就会自动对电脑缺失或已损坏的安装文件进行修复。windows7系统注册表文件遗失或损坏怎么办1、最先开机自检之后,立刻按住F8键,应用方向键挑选安全模式,敲打回车即可。2、以后点击开始按钮,挑选命令提示符,以管理员的身份运作。3、最后在弹出的提示符中输入SFC/

diskgenius数据怎么恢复-diskgenius数据恢复教程 diskgenius数据怎么恢复-diskgenius数据恢复教程 Mar 06, 2024 am 09:34 AM

很多小伙伴不知道diskgenius数据怎么恢复,所以下面小编就分享了diskgenius数据恢复的相关教程,一起去看看吧,相信对大家会有帮助。首先,在DiskGenius的主界面上方的硬盘分区图中,可以直接选择目标分区,右键点击。接着,在弹出的快捷菜单中,找到并点击“已删除或格式化后的文件恢复”菜单项,如图所示。在第二步中,弹出恢复选项窗口,确保勾选“恢复已删除的文件”、“完整恢复”和“额外扫描已知文件类型”这三个选项。第三步:点击右侧的“选择文件类型”按钮,在弹出的窗口中指定您需要恢复的文件

PHP参数丢失问题的解决方案 PHP参数丢失问题的解决方案 Mar 11, 2024 am 09:27 AM

PHP参数丢失问题的解决方案在开发PHP程序的过程中,经常会遇到参数丢失的问题,这可能是由于前端传递的参数不完整、后端接收参数的方式不正确等原因造成的。在本文中,我们将针对PHP参数丢失问题提供一些解决方案,并附上具体的代码示例。一、前端传参问题使用GET方法传递参数当使用GET方法传递参数时,参数会以URL参数的形式附加在请求的URL后面。在后端接收参数时

ThinkPHP6数据备份与恢复:保障数据的安全性 ThinkPHP6数据备份与恢复:保障数据的安全性 Aug 13, 2023 am 08:28 AM

ThinkPHP6数据备份与恢复:保障数据的安全性随着互联网的快速发展,数据已成为一项极其重要的资产。因此,数据的安全性备受关注。在Web应用开发中,数据备份与恢复是确保数据安全的重要一环。在本文中,我们将介绍如何使用ThinkPHP6框架进行数据备份与恢复,以保障数据的安全性。一、数据备份数据备份是指将数据库中的数据以某种方式进行复制或存储。这样即使在数据

如何处理硬盘扇区损坏问题 如何处理硬盘扇区损坏问题 Feb 19, 2024 am 11:03 AM

硬盘扇区坏了怎么解决硬盘扇区坏了是一个常见的硬件故障,它可能导致数据丢失,影响计算机的性能。了解和解决硬盘扇区坏了的问题是非常重要的。本文将介绍硬盘扇区的概念,讨论常见的硬盘扇区坏了的原因以及解决办法。一、什么是硬盘扇区?在介绍如何解决硬盘扇区坏了的问题之前,我们首先来了解一下什么是硬盘扇区。硬盘扇区是硬盘驱动器上最小的可读写单元,它是硬盘中的一小段空间,用

如何在Laravel中使用中间件进行数据恢复 如何在Laravel中使用中间件进行数据恢复 Nov 02, 2023 pm 02:12 PM

Laravel是一个流行的PHPWeb应用程序框架,提供了许多快速而又简单的方式来构建高效、安全和可扩展的Web应用程序。在开发Laravel应用程序时,我们经常需要考虑数据恢复的问题,即如何在数据丢失或损坏的情况下恢复数据并保证应用程序的正常运行。在本文中,我们将介绍如何使用Laravel中间件来实现数据恢复功能,并提供具体的代码示例。一、什么是Lara

如何快速恢复MySQL数据库遭遇的故障和错误? 如何快速恢复MySQL数据库遭遇的故障和错误? Sep 10, 2023 pm 03:45 PM

如何快速恢复MySQL数据库遭遇的故障和错误?MySQL是一种广泛使用的开源关系型数据库管理系统,许多应用程序和网站都依赖于它来存储和管理数据。然而,数据库故障和错误是不可避免的,这可能导致数据丢失或应用程序无法正常运行。在遭遇MySQL数据库故障或错误时,快速而有效地恢复数据库非常重要。本文将介绍一些快速恢复MySQL数据库的方法。确定故障和错误的类型在开

Linux系统文件损坏与丢失应对方案 Linux系统文件损坏与丢失应对方案 Jun 30, 2023 am 09:29 AM

标题:如何应对Linux系统中的文件损坏和丢失问题引言:在使用Linux系统的过程中,文件损坏和丢失是一个不容忽视的问题。由于各种原因,我们可能会面临文件丢失、文件损坏或无法访问文件的情况。然而,幸运的是,Linux系统提供了一些实用工具和技术,帮助我们有效地应对文件损坏和丢失问题。本文将介绍一些常见的解决方法和技巧。一、备份数据备份是最重要的应对文件损坏和

See all articles