情况描述:<o:p></o:p>
SQL Server 2000崩溃,重新安装数据库。<o:p></o:p>
有以下准备:<o:p></o:p>
1, 三个系统库(master,msdb,model)的完全备份:<o:p></o:p>
2 两个用户数据库(user01,user02)的备份(周日的完全备份+除周日外每天的差异备份):<o:p></o:p>
三个系统数据库是早期备份的,之间没有更新过帐号信息,没有增减过作业等等。<o:p></o:p>
两个用户数据库在上周日晚做过完全备份(user01.bak和user02.bak)<o:p></o:p>
<o:p> </o:p>
准备重新安装数据库,希望能一次性恢复到用户数据库最后一个备份前的状态。<o:p></o:p>
<o:p> </o:p>
<o:p> </o:p>
常规恢复过程大致如下<o:p></o:p>
<o:p> </o:p>
1. 备份可用的数据, 包含所有系统数据库和用户数据库的数据文件和日志文件(*.mdf/ldf/ndf)<o:p></o:p>
2. 卸载原来的安装<o:p></o:p>
3. 系统表查找和删除所有的MSSQLServer项<o:p></o:p>
4. 磁盘上删除安装SQL SErver产生的所有文件<o:p></o:p>
<o:p> </o:p>
5. 重新安装SQL Server,所需安装的补丁的版本要求保持与备份系统数据库时安装的补丁版本一致<o:p></o:p>
<o:p> </o:p>
6. 单用户模式下恢复master数据库<o:p></o:p>
7. 恢复其他系统数据库<o:p></o:p>
8. 恢复用户数据库<o:p></o:p>
<o:p> </o:p>
<o:p> </o:p>
可以做的尝试<o:p></o:p>
如果时间比较充分,而且想尽量恢复数据到最近的时间点, 可以在上述步骤中做下面的尝试<o:p></o:p>
<o:p> </o:p>
1. 把6,7两步改为:<o:p></o:p>
a. 停止MSSQL服务<o:p></o:p>
b. 用步骤1备份的系统数据库的数据文件和日志文件替换安装后生成的系统数据库的对应文件<o:p></o:p>
c. 建立与SQL Server系统崩溃之前一样的用户数据库的存放目录, 并且把用户数据库文件按原来的位置存放<o:p></o:p>
d. 启动MSSQL服务<o:p></o:p>
e. 如果MSSQL服务成功, 在企业管理看看用户数据库有没有置疑, 如果没有置疑, 则其他操作都不用做了, 数据已经恢复<o:p></o:p>
<o:p> </o:p>
注意:<o:p></o:p>
在做上面的步骤b之前, 先备份准备覆盖的文件<o:p></o:p>
<o:p> </o:p>
2. 如果步骤1的尝试不成功, 则再做下面的尝试, 把步骤8修改为下面的:<o:p></o:p>
a. 停止MSSQL服务<o:p></o:p>
b. 用备份的文件还原被覆盖的文件<o:p></o:p>
c. 尝试用附加的方式恢复用户数据库<o:p></o:p>
d. 如果成功, 则修复各用户数据库中的孤立用户<o:p></o:p>
<o:p> </o:p>
<o:p> </o:p>
恢复过程会涉及到的一些具体处理<o:p></o:p>
<o:p> </o:p>
1. 恢复系统数据库:<o:p></o:p>
在SQL Server数据库中,系统信息存储在系统数据库中,主要的系统数据库包括: <o:p></o:p>
master-从整体上控制用户数据库和SQL Server操作,在创建了任何用户定义的对象后,都要备份它<o:p></o:p>
model-为新数据库提供模版和原型 <o:p></o:p>
msdb-包含了有关作业、报警及操作员等信息<o:p></o:p>
<o:p> </o:p>
如果包含系统数据库的介质变了,那么必须重建系统数据库,如果你仍然可以启动SQL Server服务,则可以通过RESTORE语句从系统数据库的备份中恢复数据库。 <o:p></o:p>
如果master坏了,不能启动系统,可以按照下面步骤进行恢复 <o:p></o:p>
1. 重建系统数据库 运行c:\mssql7\binn\rebuildm.exe,按照提示进行即可,<o:p></o:p>
过程中需要系统数据库样本的路径,可在安装光盘中找到; <o:p></o:p>
<o:p> </o:p>
2 重建系统数据库后,启动SQL Server服务,用系统数据库的备份恢复数据库<o:p></o:p>
就行了通常恢复顺序为master->msdb->model <o:p></o:p>
在恢复master的备份时要注意:必须在单用户(single user)模式下进行<o:p></o:p>
进入单用户模式的方法: <o:p></o:p>
a. 在命令行模式下输入:sqlservr -c -f -m或者输入sqlservr -m <o:p></o:p>
其中:-c 可以缩短启动时间,SQL Server 不作为Windows NT的服务启动 <o:p></o:p>
-f 用最小配置启动SQL Server <o:p></o:p>
-m 单用户模式启动SQL Server <o:p></o:p>
<o:p> </o:p>
b. 可以在控制面板-服务-MSSQLServer的启动参数中输入-c -f -m或者输入-m,点击开始 <o:p></o:p>
<o:p></o:p>
3. 进行master数据库的恢复