数据库系统崩溃后的一般处理步骤

原创 2006年07月01日 21:59:00

情况描述:

SQL Server 2000崩溃,重新安装数据库。

有以下准备:

1, 三个系统库(master,msdb,model)的完全备份:

2  两个用户数据库(user01,user02)的备份(周日的完全备份+除周日外每天的差异备份):

三个系统数据库是早期备份的,之间没有更新过帐号信息,没有增减过作业等等。

两个用户数据库在上周日晚做过完全备份(user01.bakuser02.bak

 

准备重新安装数据库,希望能一次性恢复到用户数据库最后一个备份前的状态。

 

 

常规恢复过程大致如下

 

1. 备份可用的数据, 包含所有系统数据库和用户数据库的数据文件和日志文件(*.mdf/ldf/ndf)

2. 卸载原来的安装

3. 系统表查找和删除所有的MSSQLServer

4. 磁盘上删除安装SQL SErver产生的所有文件

 

5. 重新安装SQL Server,所需安装的补丁的版本要求保持与备份系统数据库时安装的补丁版本一致

 

6. 单用户模式下恢复master数据库

7. 恢复其他系统数据库

8. 恢复用户数据库

 

 

可以做的尝试

如果时间比较充分,而且想尽量恢复数据到最近的时间点, 可以在上述步骤中做下面的尝试

 

1. 6,7两步改为:

a. 停止MSSQL服务

b. 用步骤1备份的系统数据库的数据文件和日志文件替换安装后生成的系统数据库的对应文件

c. 建立与SQL Server系统崩溃之前一样的用户数据库的存放目录, 并且把用户数据库文件按原来的位置存放

d. 启动MSSQL服务

e. 如果MSSQL服务成功, 在企业管理看看用户数据库有没有置疑, 如果没有置疑, 则其他操作都不用做了, 数据已经恢复

 

注意:

    在做上面的步骤b之前, 先备份准备覆盖的文件

 

2. 如果步骤1的尝试不成功, 则再做下面的尝试, 把步骤8修改为下面的:

a. 停止MSSQL服务

b. 用备份的文件还原被覆盖的文件

c. 尝试用附加的方式恢复用户数据库

d. 如果成功, 则修复各用户数据库中的孤立用户

 

 

恢复过程会涉及到的一些具体处理

 

1. 恢复系统数据库:

SQL Server数据库中,系统信息存储在系统数据库中,主要的系统数据库包括:

master-从整体上控制用户数据库和SQL Server操作,在创建了任何用户定义的对象后,都要备份它

model-为新数据库提供模版和原型

msdb-包含了有关作业、报警及操作员等信息

 

如果包含系统数据库的介质变了,那么必须重建系统数据库,如果你仍然可以启动SQL Server服务,则可以通过RESTORE语句从系统数据库的备份中恢复数据库。

如果master坏了,不能启动系统,可以按照下面步骤进行恢复

1. 重建系统数据库 运行c:/mssql7/binn/rebuildm.exe,按照提示进行即可,

过程中需要系统数据库样本的路径,可在安装光盘中找到;

 

2  重建系统数据库后,启动SQL Server服务,用系统数据库的备份恢复数据库

就行了通常恢复顺序为master->msdb->model

在恢复master的备份时要注意:必须在单用户(single user)模式下进行

进入单用户模式的方法:

a. 在命令行模式下输入:sqlservr -c -f -m或者输入sqlservr -m

其中:-c 可以缩短启动时间,SQL Server 不作为Windows NT的服务启动

-f 用最小配置启动SQL Server

-m 单用户模式启动SQL Server

 

b. 可以在控制面板-服务-MSSQLServer的启动参数中输入-c -f -m或者输入-m,点击开始

 

3. 进行master数据库的恢复

a. 直接进入查询分析器,有个提示不要理会它

输入恢复语句进行数据库恢复:

RESTORE DATABASE master from disk='c:/具体的备份文件名'

 

b. 或者用这个,在命令提示符下输入,注意大小写

使用"windows身份验证",输入:isql /E

使用"sql serverwindows身份验证",输入:isql /U"用户名" /P"密码"

然后在出现的提示符下输入(注意1>,2>是提示符):

1>RESTORE DATABASE master from disk='c:/具体的备份文件名'

2>GO

 

2. 还原数据库的具体步骤:

1. 恢复最近一次的完整备份

企业管理器--右键"数据库"--所有任务--还原数据库

--"还原为数据库库"中输入还原后的数据库名,设为:test

--还原选择"从设备"--选择设备--添加--添加你的备份文件

--确定,回到数据库还原的界面

--"还原备份集",选择"数据库--完全"

--选项--"移至物理文件名"中的物理文件名修改为你的数据文件要存放的文件名

--如果要还原的数据库已经存在,选择"在现有数据库上强制还原"

--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"

--确定

 

--或用SQL语句:

RESTORE DATABASE 数据库名

FROM DISK = 'c:/你的完全备份文件名'

WITH NORECOVERY

 

 

2. 恢复完全备份后, 最近一次的差异备份(如果有的话)

企业管理器--右键"数据库"--所有任务--还原数据库

--"还原为数据库库"中选择数据库名:test

--还原选择"从设备"--选择设备--添加--添加你的备份文件

--确定,回到数据库还原的界面

--"还原备份集",选择"数据库--差异"

--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"

--确定

 

--或用SQL语句:

--或用SQL语句:

RESTORE DATABASE 数据库名

FROM DISK = 'c:/你的差异备份文件名'

WITH NORECOVERY

 

 

3. 按时间先后, 恢复差异备份后(如果没有差异备份,则是完全备份)的所有日志备份

企业管理器--右键"数据库"--所有任务--还原数据库

--"还原为数据库库"中选择数据库名:test

--还原选择"从设备"--选择设备--添加--添加你的备份文件

--确定,回到数据库还原的界面

--"还原备份集",选择"事务日志"

--"恢复完成状态"

   如果是恢复最后一个日志文件,选择"使数据库可以继续运行,但无法还原其它事务日志"

   否则选择"使数据库不再运行,但能还原其它事务日志"

--确定

 

--或用SQL语句:

RESTORE DATABASE 数据库名

FROM DISK = 'c:/你的日志文件名'

WITH RECOVERY

 

3. 解决孤立用户:

1. 查看某个数据库的孤立用户:

USE 库名

EXEC sp_change_users_login 'Report'

 

2. 自动修复某个孤立用户:

USE 库名

EXEC sp_change_users_login 'Auto_Fix', '孤立用户名', NULL, '密码' 

  --密码指用户对应的登录不存在时, 系统自动建立登录, 为登录分配的密码

 

机房收费系统重构(1)——数据库崩溃了

背景:本来一直在敲机房收费系统个人版来着,可是,数据库崩溃了,怎么打都打不开,找了很多方法,也是没有什么进展,加上最近一直在忙作品展的PPT的事,自然也就没有去理会。在PPT做完之际,我都下定决心要重...
  • u013043341
  • u013043341
  • 2015年04月04日 08:03
  • 702

数据库系统崩溃后的一般处理步骤

 数据库系统崩溃后的一般处理步骤情况描述:SQL Server 2000崩溃,重新安装数据库。有以下准备:1, 三个系统库(master,msdb,model)的完全备份:2 两个用户数据库(user...
  • bqb
  • bqb
  • 2007年06月16日 17:10
  • 562

线上Mysql数据库崩溃事故的原因和处理

- 由于有多个仓库,因此仓库也独立做了一张表; - 一个仓库中有多个货架,tb_storehouse与tb_shelf是一对多的关系; - 一个货架中有多个格子(货架规格不同,有的是8个有的是4个),...
  • ZHENFENGSHISAN
  • ZHENFENGSHISAN
  • 2017年11月13日 09:50
  • 407

一次svn数据库的崩溃错误的解决

作者:朱金灿来源:http://blog.csdn.net/clever101         同事更新一个svn数据库,出现一个错误:打开文件系统的BDB环境句柄时出错,具体如下图:...
  • clever101
  • clever101
  • 2014年06月23日 16:53
  • 3941

数据库系统崩溃后的一般处理步骤

情况描述:SQL Server 2000崩溃,重新安装数据库。有以下准备:1, 三个系统库(master,msdb,model)的完全备份:2  两个用户数据库(user01,user02)的备份(周...
  • softstars
  • softstars
  • 2008年01月03日 14:43
  • 239

转:邹建--数据库系统崩溃后的一般处理步骤

转: http://blog.csdn.net/zjcxc/archive/2006/07/01/862795.aspx情况描述:SQL Server 2000崩溃,重新安装数据库。有以下准备:1, ...
  • flyskylf
  • flyskylf
  • 2007年12月25日 13:44
  • 411

数据库系统崩溃后的一般处理步骤

情况描述:SQL Server 2000崩溃,重新安装数据库。有以下准备:1, 三个系统库(master,msdb,model)的完全备份:2  两个用户数据库(user01,user02)的备份(周...
  • zjcxc
  • zjcxc
  • 2006年07月01日 21:59
  • 7106

服务器站点崩溃的几种原因及解决方案

在计算机网络日益普及的今天,计算机安全不但要求防治计算机病毒,而且要提高系统抵抗黑客非法入侵的能力,还要提高对远程数据传输的保密性,避免在传输途中遭受非法窃取。本文仅仅讨论香港服务器租用或香港服务器托...
  • u014225431
  • u014225431
  • 2016年06月14日 09:55
  • 5325

mssql数据库系统崩溃后的一般处理步骤与方法

mssql数据库系统崩溃后的一般处理步骤 情况描述: SQL Server 2000崩溃,重新安装数据库。 有以下准备: 1, 三个系统库(master,msdb,model)的完全备份: 2 两个用...
  • wangmj518
  • wangmj518
  • 2008年12月10日 09:46
  • 368

数字图像处理的基本步骤

数字图像处理的基本步骤:
  • tuling56
  • tuling56
  • 2014年02月17日 15:27
  • 3819
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据库系统崩溃后的一般处理步骤
举报原因:
原因补充:

(最多只允许输入30个字)