SQL SERVER 9003错误解决方法

SQLSERVER 9003错误解决方法 只适用于SQL2000

(只适用于SQL2000)

"无法打开新数据库 'POS'。CREATE DATABASE 中止。 (Microsoft SQL Server,错误: 9003)"

看是9003错误,就想到可能是由于日志文件的原因,再看数据库文件可能损坏,于是想到dbcc checkdb指令.

方法如下:

1.我们使用默认方式建立一个供恢复使用的数据库(如pos)。可以在SQL   Server   Enterprise   Manager里面建立。

2.停掉数据库服务器。

3.将刚才生成的数据库的日志文件pos_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件pos_data.mdf。

4.启动数据库服务器。此时会看到数据库pos的状态为“置疑”。这时候不能对此数据库进行任何操作。

5.设置数据库允许直接操作系统表。此操作可以在SQL   Server   Enterprise   Manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。

use master go exec sp_configure 'allow updates',1 go reconfigure with override go

6.设置pos为紧急修复模式

update sysdatabases set status=-32768 where dbid=DB_ID('pos') go

此时可以在SQL   Server   Enterprise   Manager里面看到该数据库处于“只读\置疑\脱机\紧急模式”可以看到数据库里面的表,但是仅仅有系统表

7.下面执行真正的恢复操作,重建数据库日志文件

dbcc rebuild_log('pos','D:\Program Files\Microsoft SQL Server\MSSQL\Data\pos_log.ldf') go

执行过程中,如果遇到下列提示信息:
服务器:   消息   5030,级别   16,状态   1,行   1
未能排它地锁定数据库以执行该操作。
DBCC   执行完毕。如果   DBCC   输出了错误信息,请与系统管理员联系。
说明您的其他程序正在使用该数据库,如果刚才您在6步骤中使用SQL   Server   Enterprise   Manager打开了pos库的系统表,那么退出SQL   Server   Enterprise   Manager就可以了。
正确执行完成的提示应该类似于:
警告:   数据库   'pos'   的日志已重建。已失去事务的一致性。应运行   DBCC   CHECKDB   以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。
DBCC   执行完毕。如果   DBCC   输出了错误信息,请与系统管理员联系。
此时打开在SQL   Server   Enterprise   Manager里面会看到数据库的状态为“只供DBO使用”。此时可以访问数据库里面的用户表了。

8.验证数据库一致性(可省略)

dbcc checkdb('pos') go

一般执行结果如下:

CHECKDB   发现了   0   个分配错误和   0   个一致性错误(在数据库   'pos'   中)。
DBCC   执行完毕。如果   DBCC   输出了错误信息,请与系统管理员联系。

9.设置数据库为正常状态

exec sp_dboption 'pos','dbo use only','false' go

如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。

10.最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。因为平时直接操作系统表是一件比较危险的事情。当然,我们可以在SQL   Server   Enterprise   Manager里面恢复,也可以使用如下语句完成

exec sp_configure 'allow updates',0 go reconfigure with override go

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

时间: 2024-10-23 11:31:40

SQL SERVER 9003错误解决方法的相关文章

SQL SERVER 9003错误解决方法_MsSql

SQLSERVER 9003错误解决方法 只适用于SQL2000 (只适用于SQL2000) "无法打开新数据库 'POS'.CREATE DATABASE 中止. (Microsoft SQL Server,错误: 9003)" 看是9003错误,就想到可能是由于日志文件的原因,再看数据库文件可能损坏,于是想到dbcc checkdb指令. 方法如下: 1.我们使用默认方式建立一个供恢复使用的数据库(如pos).可以在SQL   Server   Enterprise   Manag

用户 'sa' 登录失败。原因: 未与信任 SQL Server 连接 的解决方法

用户 'sa' 登录失败.原因: 未与信任 SQL Server 连接 的解决方法如下: 一.控制面板->服务->MS SQL SERVER->登陆-->本地系统帐户-->重新启动MS SQL SERVER用windows验证登陆查询分析器-->执行 sp_password null,sa新密码,'sa' 二."无法连接到服务器,用户xxx登陆失败"该错误产生的原因是由于SQL Server使用了"仅 Windows"的身份验证方

关于Asp程序的Server.CreateObject错误解决方法

object|server|程序|错误|解决 由于以前一直没用过XP系统(还是在大学那会xp刚出来的时候用过,以后就一直没用过xp,当时不喜欢它花里胡哨的界面,呵呵.),没碰到过这样的问题,今天在帮一个网友mm解决excel导入到sqlserver数据库中遇到这样的问题,asp代码里无权限创建excel对象(偶的是XP Professional 英文版),大概是xp默认权限限制的问题,于是到百度里搜索了一下,找到了解决办法如下: 很多使用 IIS 架站的人 经常碰到类似的问题. 在Asp程序Cr

sql server数据库连接出错解决方法

sql server数据库教程连接出错解决方法 错误提供 "由于检索用户的本地应用程序数据路径时出错,导致无法生成 sql server 的用户实例.请确保该用户在此计算机上有本地用户配置文件.该连接将关闭. " 字符串问题 data source=".sqlexpress;attachdbfilename=|datadirectory|test.mdf;integrated security=true;user instance=false" net项目默认的数据

HTTP 错误 500.19- Internal Server Error 错误解决方法

在本机部署了一个WebService测试,浏览的时候出现了"HTTP 错误 500.19 - Internal Server Error "错误,如下图: 1 打开运行,输入cmd进入到命令提示符窗口. 2 进入到C:WINDOWSMicrosoft.NETFrameworkv2.0.50727 目录. 3 输入asp教程net_regiis.exe –i 执行既可 注意:如果系统为64位 第二步的路径为C:WINDOWSMicrosoft.NETFramework64v2.0.507

HTTP 错误 500.19- Internal Server Error 错误解决方法_win服务器

刚在本机部署了一个WebService测试,浏览的时候出现了"HTTP 错误 500.19 - Internal Server Error "错误,如下图: 经过检查发现是由于先安装vs2008后安装iis的缘故,只需重新注册下AspNet就可以了,具体步骤如下 1 打开运行,输入cmd进入到命令提示符窗口. 2 进入到C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727 目录. 3 输入aspnet_regiis.exe –i 执行既可 注意:如

SQL Server常见问题及解决方法分享

写在前面 在QQ群,微信群,论坛中经常帮助使用SQL Server数据库的朋友解决问题,但是有一些最常见最基本的问题,每天都有人问,回答多了也不想再解答了,索性把这些问题整理一下,再有人问到直接发链接. 一时想法而写这篇文章,问题可能不全面,后续会一直更新. 基础问题收集资源下载 描述:XX版本数据库操作系统在哪里下载? 答:http://www.itellyou.cn/ 里面很多东西,有兴趣的自己看吧 连接问题 描述:数据库连接不上 答:请确认SQL服务是否启动,用户密码是否正确,连接的实例名

SQL Server置疑数据库解决方法

1.首先确认已经备份了.mdf和.ldf文件. 2. 在SQL Server中新建一个同名的数据库,然后停止SQL Server服务. 3. 用原有的.mdf和.ldf文件覆盖新建数据库对应的.mdf和.ldf文件. 4. 重新启动SQL Server服务,这是应该会看到这个数据库处于置疑(Suspect)状态. 5. 在SQL查询分析器中执行以下命令,以允许更新系统表: use mastergosp_configure 'allow updates',1reconfigure with ove

python连接sql server乱码的解决方法_python

vi /etc/freetds/freetds.conf 复制代码 代码如下: [global]# TDS protocol versiontds version = 8.0client charset = UTF-8# A typical Microsoft server[Server55]host = 192.168.1.55port = 1433tds version = 8.0vi /etc/odbc.ini[DSN55]Description=my dsnDriver=TDSDatab