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

2022-11-12 09:51:19
内容摘要
这篇文章主要为大家详细介绍了SQL Server 数据库系统崩溃后的一般处理步骤与方法,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记!mssql数
文章正文

这篇文章主要为大家详细介绍了SQL Server 数据库系统崩溃后的一般处理步骤与方法,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

mssql数据库系统崩溃后的一般处理步骤情况描述:SQLServer2000崩溃,重新安装数据库。有以下准备:1,三个系统库(master,msdb,model)的完全备份:2两个用户数据库(user01,user02)的备份(周日的完全备份+除周日外每天的差异备份):三个系统数据库是早期备份的,之间没有更新过帐号信息,没有增减过作业等等。两个用户数据库在上周日晚做过完全备份(user01.bak和user02.bak)准备重新安装数据库,希望能一次性恢复到用户数据库最后一个备份前的状态。常规恢复过程大致如下1.备份可用的数据,包含所有系统数据库和用户数据库的数据文件和日志文件(*.mdf/ldf/ndf)2.卸载原来的安装3.系统表查找和删除所有的MSSQLServer项4.磁盘上删除安装SQLSErver产生的所有文件5.重新安装SQLServer,所需安装的补丁的版本要求保持与备份系统数据库时安装的补丁版本一致6.单用户模式下恢复master数据库7.恢复其他系统数据库8.恢复用户数据库可以做的尝试如果时间比较充分,而且想尽量恢复数据到最近的时间点,可以在上述步骤中做下面的尝试1.把6,7两步改为:a.停止MSSQL服务b.用步骤1备份的系统数据库的数据文件和日志文件替换安装后生成的系统数据库的对应文件c.建立与SQLServer系统崩溃之前一样的用户数据库的存放目录,并且把用户数据库文件按原来的位置存放d.启动MSSQL服务e.如果MSSQL服务成功,在企业管理看看用户数据库有没有置疑,如果没有置疑,则其他操作都不用做了,数据已经恢复注意:在做上面的步骤b之前,先备份准备覆盖的文件2.如果步骤1的尝试不成功,则再做下面的尝试,把步骤8修改为下面的:a.停止MSSQL服务b.用备份的文件还原被覆盖的文件c.尝试用附加的方式恢复用户数据库d.如果成功,则修复各用户数据库中的孤立用户恢复过程会涉及到的一些具体处理1.恢复系统数据库:在SQLServer数据库中,系统信息存储在系统数据库中,主要的系统数据库包括:master-从整体上控制用户数据库和SQLServer操作,在创建了任何用户定义的对象后,都要备份它model-为新数据库提供模版和原型msdb-包含了有关作业、报警及操作员等信息如果包含系统数据库的介质变了,那么必须重建系统数据库,如果你仍然可以启动SQLServer服务,则可以通过RESTORE语句从系统数据库的备份中恢复数据库。如果master坏了,不能启动系统,可以按照下面步骤进行恢复1.重建系统数据库运行c:\mssql7\binn\rebuildm.exe,按照提示进行即可,过程中需要系统数据库样本的路径,可在安装光盘中找到;2重建系统数据库后,启动SQLServer服务,用系统数据库的备份恢复数据库就行了通常恢复顺序为master->msdb->model在恢复master的备份时要注意:必须在单用户(singleuser)模式下进行进入单用户模式的方法:a.在命令行模式下输入:sqlservr-c-f-m或者输入sqlservr-m其中:-c可以缩短启动时间,SQLServer不作为WindowsNT的服务启动-f用最小配置启动SQLServer-m单用户模式启动SQLServerb.可以在控制面板-服务-MSSQLServer的启动参数中输入-c-f-m或者输入-m,点击开始3.进行master数据库的恢复a.直接进入查询分析器,有个提示不要理会它输入恢复语句进行数据库恢复:RESTOREDATABASEmasterfromdisk='c:\具体的备份文件名'b.或者用这个,在命令提示符下输入,注意大小写使用"windows身份验证"的,输入:isql/E使用"sqlserver和windows身份验证"的,输入:isql/U"用户名"/P"密码"然后在出现的提示符下输入(注意1>,2>是提示符):1>RESTOREDATABASEmasterfromdisk='c:\具体的备份文件名'2>GO2.还原数据库的具体步骤:1.恢复最近一次的完整备份企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中输入还原后的数据库名,设为:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"数据库--完全"--选项--将"移至物理文件名"中的物理文件名修改为你的数据文件要存放的文件名--如果要还原的数据库已经存在,选择"在现有数据库上强制还原"--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"--确定--或用SQL语句:RESTOREDATABASE数据库名FROMDISK='c:\你的完全备份文件名'WITHNORECOVERY2.恢复完全备份后,最近一次的差异备份(如果有的话)企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中选择数据库名:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"数据库--差异"--"恢复完成状态",选择"使数据库不再运行,但能还原其它事务日志"--确定--或用SQL语句:--或用SQL语句:RESTOREDATABASE数据库名FROMDISK='c:\你的差异备份文件名'WITHNORECOVERY3.按时间先后,恢复差异备份后(如果没有差异备份,则是完全备份)的所有日志备份企业管理器--右键"数据库"--所有任务--还原数据库--"还原为数据库库"中选择数据库名:test--还原选择"从设备"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面--"还原备份集",选择"事务日志"--"恢复完成状态"如果是恢复最后一个日志文件,选择"使数据库可以继续运行,但无法还原其它事务日志"否则选择"使数据库不再运行,但能还原其它事务日志"--确定--或用SQL语句:RESTOREDATABASE数据库名FROMDISK='c:\你的日志文件名'WITHRECOVERY3.解决孤立用户:1.查看某个数据库的孤立用户:USE库名EXECsp_change_users_login'Report'2.自动修复某个孤立用户:USE库名EXECsp_change_users_login'Auto_Fix','孤立用户名',NULL,'密码'--密码指用户对应的登录不存在时,系统自动建立登录,为登录分配的密码

注:关于SQL Server 数据库系统崩溃后的一般处理步骤与方法的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!