当前位置:  数据库>sqlserver

SQLSERVER数据库中的5173错误解决方法

    来源: 互联网  发布时间:2014-10-10

    本文导语:  昨天同事给你我一个有问题的数据库,叫我修复一下因为客户那边需要这个数据库,这个数据库只有一个mdf文件和一个ldf文件, 当我附加数据库的时候报错,数据库是SQL2005 附上有损坏的数据库文件: 因为之前在论坛也遇到过...

昨天同事给你我一个有问题的数据库,叫我修复一下因为客户那边需要这个数据库,这个数据库只有一个mdf文件和一个ldf文件,

当我附加数据库的时候报错,数据库是SQL2005

附上有损坏的数据库文件:

因为之前在论坛也遇到过,所以按照论坛的方法来解决,结果还是不行

把ldf文件移到别的地方,然后附加的时候使用下面SQL语句重建事务日志文件

我的数据库文件放在C:UsersAdministratorDesktop新建文件夹目录下

代码如下:

USE [master]
GO
CREATE DATABASE [AdventureWorks2012] ON
( FILENAME = N'C:UsersAdministratorDesktop新建文件夹GPOSDB.mdf' )
FOR ATTACH_REBUILD_LOG
GO

报错内容:
代码如下:

1 文件激活失败。物理文件名称'D:MSSSQLDataGPOSDB_log.LDF'可能不正确。
2 由于数据库没有完全关闭,无法重新生成日志。
3 消息 1813,级别 16,状态 2,第 1 行
4 无法打开新数据库 'GPOSDB'。CREATE DATABASE 中止。

我现在按照这篇文章再试一下

http://www.blogjava.net/kent/articles/200991.html

先新建一个GPOSDB的空库,然后停掉SQL服务

将刚才生成的数据库的日志文件GPOSDB_log.ldf删除

用要恢复的GPOSDB.mdf文件覆盖刚才生成的数据库数据文件GPOSDB.mdf

然后把有问题的GPOSDB.mdf文件放在D盘,因为我新建的GPOSDB数据库放在D盘

启动SQL服务

文章说会显示数据库置疑,但是我的没有显示置疑

设置数据库允许直接操作系统表

在SSMS里输入下面SQL语句

代码如下:

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

设置GPOSDB为紧急修复模式
代码如下:

ALTER DATABASE [GPOSDB] SET EMERGENCY
GO
ALTER DATABASE GPOSDB SET SINGLE_USER
GO

UPDATE sysdatabases
SET status = -32768
WHERE dbid = DB_ID('GPOSDB')
GO

但是报错
代码如下:

1 消息 259,级别 16,状态 1,第 1 行
2 不允许对系统目录进行即席更新。

尝试重建日志,但是语法错误,估计那篇文章是SQL2000的
代码如下:

1 DBCC rebuild_log('GPOSDB','D:GPOSDB_log.ldf')
2 GO
1 消息 2526,级别 16,状态 3,第 1 行
2 DBCC 语句错误。请查阅文档以了解正确的 DBCC 语法和选项。

一查果然是

--* DBCC REBUILDLOG
--重建SQL Server 2000事务日志文件

其实一开始在步骤“设置数据库允许直接操作系统表” 就怀疑是不是SQL2000的,因为SQL2005或以后已经不能修改系统表了

最后把事务日志文件也放到D盘,然后使用下面的SQL语句来修复还是不行

代码如下:

ALTER DATABASE [GPOSDB] SET EMERGENCY
GO
ALTER DATABASE GPOSDB SET SINGLE_USER
GO

DBCC CheckDB (GPOSDB, REPAIR_ALLOW_DATA_LOSS)
GO

代码如下:

消息 5173,级别 16,状态 1,第 2 行
一个或多个文件与数据库的主文件不匹配。如果是尝试附加数据库,请使用正确的文件重试该操作。如果这是现有数据库,则文件可能已损坏,应该从备份进行还原。
日志文件 'D:GPOSDB_log.ldf' 与主文件不匹配。该文件可能来自另一数据库,或者可能以前重新生成了日志。
消息 5123,级别 16,状态 1,第 2 行
尝试打开或创建物理文件 'D:MSSSQLDataGPOSDB_log.LDF' 时,CREATE FILE 遇到操作系统错误 3(系统找不到指定的路径。)。
消息 5024,级别 16,状态 2,第 2 行
在 sysfiles1 中找不到主日志文件所对应的条目。无法重建日志。
消息 5028,级别 16,状态 2,第 2 行
系统无法激活足够的数据库来重建日志。
GPOSDB的 DBCC 结果。
CHECKDB 在数据库 'GPOSDB' 中发现 0 个分配错误和 0 个一致性错误。
消息 7909,级别 20,状态 1,第 2 行
紧急模式修复失败。您必须从备份中还原。

 


    
 
 

您可能感兴趣的文章:

  • sqlserver登陆后报不能为空不能为null的错误
  • SQLserver2000 企业版 出现"进程51发生了严重的异常"错误的处理方法
  • 用户"sa"登陆失败 SQLServer 错误18456的解决方法
  • sqlserver 错误602,未能在sysindexes中找到数据库 的解决办法
  • sqlserver 此数据库没有有效所有者错误的解决方法
  • SQLSERVER启动不起来(错误9003)的解决方法分享
  • SQLServer2000 报1053错误(服务没有及时响应或控制请求)的解决方法
  • SQLServer 连接失败错误故障的分析与排除
  • 连接sqlserver的url是jdbc:microsoft:sqlserver://192.168.0.100:1433,他连那一个数据库呢?
  • 怎样用文JDBC for sqlserver访问SQLSERVER 数据库请大侠给出一个完整的程序代码
  • 如何连接sqlserver2000数据库
  • shell脚本读取rrd文件将数据插入sqlserver数据库中
  • 设置密码保护的SqlServer数据库备份文件与恢复文件的方法
  • 如何使用JSP 连接SQLSERVER数据库,请不吝赐教!(在线等,急救!)
  • 如何用SQLServer2k-JDBC连接数据库?
  • 连接sqlserver的url是jdbc:microsoft:sqlserver://192.168.0.100:1433,他连那一个数据库呢? iis7站长之家
  • 请教:如何将SQLSERVER数据库中所有表结构导出???
  • JDBC连接SQLServer数据库问题!!!
  • 高分求救!!!怎样在linux下配置tomcat文件?同时配置sqlServer数据库?
  • sqlserver中如何防止数据库被下载
  • SQLServer中master数据库分析
  • !!!在Java中如何取得Resultset中的datetime和timestamp字段?数据库是SQLServer
  • 怎样一次取得sqlserver数据库的日期和时间?
  • sqlserver只有MDF文件恢复数据库的方法
  • 中文问题:我的数据库中,中文写入没有问题,但中文却不能正常读出。(sqlserver2000)
  • sqlserver 查询数据库大小的方法
  • 调查服务器系统BSD,SCO,Linux,windows?和数据库mysql,oracle,sqlserver?
  • sqlserver数据库迁移后,孤立账号解决办法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • (100分)用Microsoft jdbc Driver for sqlserver2000(type4)访问sqlserver2k的问题,help!
  • 通过SQLSERVER重启SQLSERVER服务和计算机的方法
  • (100分)jdbc连接sqlserver 200出错.[SQLServer 2000 Driver for JDBC]Error establishing socket.
  • 深入JDBC sqlserver连接写法的详解
  • how to 连接到sqlserver2000?
  • 请问如何直接sqlserver?
  • SQLServer JDBC Driver
  • 在sqlserver2000时中文问题。
  • 简单实现SQLServer转MYSQL的方法
  • 求助!SQLServer2000 JDBC Driver 不能加载?
  • Resin+Jsp+Sqlserver2000的问题!在线等候!
  • applet用jdbc链接SQLServer 2000的问题
  • 请问连接SQLServer 的驱动器是什么呢?
  • jdbc:microsoft:sqlserver://localhost:1433;DatabaseNameOPTIONAL=webmail???
  • 关于用jdbc连接sqlserver2000的问题(在线)
  • 到什么地方去下载在jbuilder6.0中使用sqlserver2000的驱动程序呀?
  • 请问如何把vfp中的数据转换到sqlserver中,高分,急!!!
  • 使用cmd命令行窗口操作SqlServer的方法
  • 为什么用sqlserver生成的创建表的sql语句中都不包含主键信息???
  • 关于数据源的问题(jbuilder和 MS SQLServer 2000)


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3