背景:由于服务器硬盘损坏,服务器异常关机。重新进入后,数据库为质疑状态。(数据库名字上面有个感叹号,连接不了)
经过无数次的百度以及大佬们的指点下,终于成功恢复,下面来说一下方法。
第一种:
1、在服务器上停掉出问题的数据库服务,把.mdf数据库文件和.ldf日志文件拷贝至本地。
2、本地新建一个同名数据库,找到文件地址,停掉sql服务后。把.mdf文件删掉(可以也把.ldf也删掉,但删不删除我都试过了,最后都会重新生成一个新的.ldf的文件,所以这里没啥特别要注意的地方),再把服务器上拷贝的.mdf文件粘贴到该路径下面。实际上就是替换一下。
3、开启sql服务,此时数据库还是不能用,执行下面指令,使数据库进入紧急状态
alter database 出问题的数据库的名字 set emergency
(设置完后可以弄一下停止,重启sql服务,主要是看了很多答案,有的说弄一下,我只是跟风,不重启sql服务也行吧,反正我重启了)
4、执行下面指令,使数据库进入单用户模式
alter database 出问题的数据库的名字 set single_user
5.1、检查并重建日志文件
dbcc checkdb('出问题的数据库的名字',REPAIR_ALLOW_DATA_LOSS)
(我数据库8.5G,我大概跑了30分钟,另外一个配置好一点电脑跑了10多分钟,这一步