论坛升级前的MYD数据能恢复回来吗?

shaguakading 2011-05-09 11:19:28
发生问题的原因是这样的:
为了升级discuz版本,对mysql进行备份,结果备错了数据库,想要备的discuz库并没有备份,然后就进行了论坛版本升级,结果数据全失。好在2010年9月做过一次备份,经过恢复,论坛的数据全都是2010年9月以前的。请问,这种情况下,还能找回2010年9月至2011年5月的数据吗?用什么方法呢?
...全文
78 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
ACMAIN_CHM 2011-05-10
  • 打赏
  • 举报
回复
[Quote]找回2010年9月至2011年5月的数据吗?用什么方法呢?[/Quote]可以通过BINLOG进行恢复,但前提是你打开了MYSQL的BINLOG功能。
[Quote]
8.6. mysqlbinlog:用于处理二进制日志文件的实用工具
服务器生成的二进制日志文件写成二进制格式。要想检查这些文本格式的文件,应使用mysqlbinlog实用工具。

应这样调用mysqlbinlog:

shell> mysqlbinlog [options] log-files...
例如,要想显示二进制日志binlog.000003的内容,使用下面的命令:

shell> mysqlbinlog binlog.0000003
输出包括在binlog.000003中包含的所有语句,以及其它信息例如每个语句花费的时间、客户发出的线程ID、发出线程时的时间戳等等。

通常情况,可以使用mysqlbinlog直接读取二进制日志文件并将它们用于本地MySQL服务器。也可以使用--read-from-remote-server选项从远程服务器读取二进制日志。

当读取远程二进制日志时,可以通过连接参数选项来指示如何连接服务器,但它们经常被忽略掉,除非你还指定了--read-from-remote-server选项。这些选项是--host、--password、--port、--protocol、--socket和--user。

还可以使用mysqlbinlog来读取在复制过程中从服务器所写的中继日志文件。中继日志格式与二进制日志文件相同。

在5.11.3节,“二进制日志”中详细讨论了二进制日志。

mysqlbinlog支持下面的选项:

· ---help,-?

显示帮助消息并退出。

· ---database=db_name,-d db_name

只列出该数据库的条目(只用本地日志)。

· --force-read,-f

使用该选项,如果mysqlbinlog读它不能识别的二进制日志事件,它会打印警告,忽略该事件并继续。没有该选项,如果mysqlbinlog读到此类事件则停止。

· --hexdump,-H

在注释中显示日志的十六进制转储。该输出可以帮助复制过程中的调试。在MySQL 5.1.2中添加了该选项。

· --host=host_name,-h host_name

获取给定主机上的MySQL服务器的二进制日志。

· --local-load=path,-l pat

为指定目录中的LOAD DATA INFILE预处理本地临时文件。

· --offset=N,-o N

跳过前N个条目。

· --password[=password],-p[password]

当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。

· --port=port_num,-P port_num

用于连接远程服务器的TCP/IP端口号。

· --position=N,-j N

不赞成使用,应使用--start-position。

· --protocol={TCP | SOCKET | PIPE | -position

使用的连接协议。

· --read-from-remote-server,-R

从MySQL服务器读二进制日志。如果未给出该选项,任何连接参数选项将被忽略。这些选项是--host、--password、--port、--protocol、--socket和--user。

· --result-file=name, -r name

将输出指向给定的文件。

· --short-form,-s

只显示日志中包含的语句,不显示其它信息。

· --socket=path,-S path

用于连接的套接字文件。

· --start-datetime=datetime

从二进制日志中第1个日期时间等于或晚于datetime参量的事件开始读取。datetime值相对于运行mysqlbinlog的机器上的本地时区。该值格式应符合DATETIME或TIMESTAMP数据类型。例如:

shell> mysqlbinlog --start-datetime="2004-12-25 11:25:56" binlog.000003
该选项可以帮助点对点恢复。

· --stop-datetime=datetime


[/Quote]
shaguakading 2011-05-09
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 rucypli 的回复:]

平时不备份的反面教材
[/Quote]
批评的极是:``(
shaguakading 2011-05-09
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 wwwwb 的回复:]

表什么 引擎?
[/Quote]
引擎指什么?
数据库是mysql,每个表有三个扩展名,分别是.frm、.MYD、.MYI
rucypli 2011-05-09
  • 打赏
  • 举报
回复
平时不备份的反面教材
wwwwb 2011-05-09
  • 打赏
  • 举报
回复
表什么 引擎?

56,940

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧