数据库还能够修复吗?

愉快的登山者 2003-01-20 12:14:47
我的一个客户,上周六因为突然停电,来电后重起机器发现数据库出了毛病:
在企业管理器中看到,数据库成了:
公司数据库(suspect)
(no items)
数据库在近期内,也没有进行过备份。
有谁能知道,这种情况数据库还能够修复好吗?
怎样才能修复?
...全文
77 25 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
pengdali 2003-01-21
  • 打赏
  • 举报
回复
看看登山GG搞定了没有!
bbksimon 2003-01-21
  • 打赏
  • 举报
回复
先copy备份,然后用sp_attach_db重建数据库,记住不要使用旧的ldf,新建一个同名的日志文件试试.可能数据能恢复
xlhl 2003-01-21
  • 打赏
  • 举报
回复
关注
j9988 2003-01-21
  • 打赏
  • 举报
回复
数据库出问题了,通过强行修改状态而恢复过来.再运行后果不得而知.

这个数据库文件就最好不要用了,不论怎么样导出到新的数据库文件中.再使用.
linfuyong 2003-01-21
  • 打赏
  • 举报
回复
有趣
tjan 2003-01-21
  • 打赏
  • 举报
回复
用 bcp 把数据弄出来吧
愉快的登山者 2003-01-21
  • 打赏
  • 举报
回复
用下列方法,在企业管理器中看到了数据库的内容:
sp_configure 'allow updates',1
go
reconfigure with override
go
use master
update sysdatabases set status =-32768 where name='公司数据库'
go
sp_configure 'allow updates',0
go
reconfigure with override
再用set status =4194308 ,将状态恢复。
数据库重起后,在企业管理器中,查看'公司数据库'的属性,只有数据文件,没有日志文件;
数据库虽然能看到,但是还是不能在应用中使用;
此时想备份此数据库,提示:
Server: Msg 3033, Level 16, State 1, Line 1
BACKUP DATABASE cannot be used on a database opened in emergency mode.
Server: Msg 3013, Level 16, State 1, Line 1
Backup or restore operation terminating abnormally.
下一步怎么使数据处于正常状态,各位高手,大侠们帮忙。

愉快的登山者 2003-01-20
  • 打赏
  • 举报
回复
SQL SERVER LOGS:
Starting up database '公司数据库'.
Opening file d:\MSSQL7\DATA\公司数据库.mdf.
Opening file d:\MSSQL7\DATA\公司数据库_log.ldf.
Bypassing recovery for database '公司数据库' because it is marked SUSPECT.
CABO 2003-01-20
  • 打赏
  • 举报
回复
重启。。。?
试试磁盘检测什么的。。。
我也不知道。。。
吃过亏。。。
强烈关注。。。
pengdali 2003-01-20
  • 打赏
  • 举报
回复
先脱机-->再联机试试!
关注!
pengdali 2003-01-20
  • 打赏
  • 举报
回复
建同名数据库,覆盖!
估计也不行
服务器买ups!
jin888888 2003-01-20
  • 打赏
  • 举报
回复
難說﹐可能要費一些心了。
看你用的是磁盤陣列還是單個硬盤了。
是用NT 或 Win2k﹐快用磁盤修復工具吧。
y_zhi_yong 2003-01-20
  • 打赏
  • 举报
回复
用附加数据库可以吗?
CSDNM 2003-01-20
  • 打赏
  • 举报
回复
以下方法应该是第一时间试的!


重置置疑状态
如果 SQL Server 因为磁盘驱动器不再有可用空间,而不能完成数据库的恢复,那么 Microsoft® SQL Server™ 2000 会返回错误 1105 并且将 sysdatabases 中的 status 列设为置疑。按下面的步骤解决这个问题:

执行 sp_resetstatus。


用 ALTER DATABASE 向数据库添加一个数据文件或日志文件。


停止并重新启动 SQL Server。
用新的数据文件或日志文件所提供的额外空间,SQL Server 应该能完成数据库的恢复。

释放磁盘空间并且重新运行恢复操作。
sp_resetstatus 关闭数据库的置疑标志,但是原封不动地保持数据库的其它选项。



注意 只有在您的主要支持提供者指导下或有疑难解答建议的做法时,才可以使用 sp_resetstatus。否则,可能会损坏数据库。


由于该过程修改了系统表,系统管理员必须在创建这个过程前,启用系统表更新。要启用更新,使用下面的过程:

USE master
GO
sp_configure 'allow updates', 1
GO
RECONFIGURE WITH OVERRIDE
GO

过程创建后,立即禁用系统表更新:

sp_configure 'allow updates', 0
GO
RECONFIGURE WITH OVERRIDE
GO

只有系统管理员才能执行 sp_resetstatus。执行该过程后,立即关闭 SQL Server。

语法为:

sp_resetstatus database_name

下面的例子将关闭 PRODUCTION 数据库的置疑标志。

sp_resetstatus PRODUCTION



pengdali 2003-01-20
  • 打赏
  • 举报
回复
有哪位大侠帮帮忙呀!
pengdali 2003-01-20
  • 打赏
  • 举报
回复
错误 5013
严重级别 16
消息正文
不能向 master 和 model 数据库添加文件。ALTER DATABASE 已终止。

解释
当试图通过添加数据库文件扩展 master 或 model 数据库时发生该错误。

对策
仅在必要时才扩展 master 或 model 数据库。如果需要,master 数据库会自动增长。如果 master 文件驻留的磁盘驱动器没有空间,则要么删除其它文件以腾出更多的磁盘空间,要么以较大的磁盘驱动器替代该磁盘驱动器。如果需要扩展 model 数据库,请确保 model 数据文件当前所驻留的磁盘驱动器具有可用的磁盘空间。
Billy_Chen28 2003-01-20
  • 打赏
  • 举报
回复
关注!
chenchangfu 2003-01-20
  • 打赏
  • 举报
回复
可以用修复安装SQL SERVER 试试,当然先备份SQLSERVER 的DATA目录
z5wjz 2003-01-20
  • 打赏
  • 举报
回复
这种情况我见过,很可能数据是找不回来了,所以最好使用备份来恢复,如果你想试试的话,可以试试我这种方法:
sp_configure 'allow updates',1
go
reconfigure with override
go
use master
update sysdatabases set status =-32768 where name='yourdbname'
go
sp_configure 'allow updates',0
go
reconfigure with override
然后重新进入SQLEM看看,这时你的库就应变成紧急状态了,看看这时候能否读出数据了,如果能读出的话基本上就可以修复.
tjan 2003-01-20
  • 打赏
  • 举报
回复
新的错误?

我的方法行吗?
加载更多回复(5)

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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