mssql server 数据库附加不上解决办法分享
发布时间:2021-12-24 22:44:56 所属栏目:MsSql教程 来源:互联网
导读:在QA里执行sp_attach_db或者sp_attach_single_file_db,出现提示:错误1813:未能打开新数据库dbname,create database 将终止。设备激活错误。物理文件名d:sql servermssqldatadbname _log.ldf可能有误! 按下面的步骤处理: 1.新建一个同名的数据库 2.再
在QA里执行sp_attach_db或者sp_attach_single_file_db,出现提示:错误1813:未能打开新数据库'dbname',create database 将终止。设备激活错误。物理文件名'd:sql servermssqldatadbname _log.ldf'可能有误! 按下面的步骤处理: 1.新建一个同名的数据库 2.再停掉sqlserver服务(注意不要分离数据库) 3.用原数据库的数据文件覆盖掉这个新建的数据库 4.再重启sqlserver服务 5.此时打开企业管理器时会出现置疑,先不管,执行下面的语句(注意修改其中的数据库名) 6.完成后一般就可以访问数据库中的数据了。这时,数据库本身一般还有问题,解决办法是:利用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了 复制代码 代码如下: use master go sp_configure 'allow updates',1 reconfigure with override go update sysdatabases set status =32768 where go sp_dboption '置疑的数据库名', 'single user', 'true' go dbcc checkdb('置疑的数据库名') go update sysdatabases set status =28 where go sp_configure 'allow updates', 0 reconfigure with override go sp_dboption '置疑的数据库名', 'single user', 'false' go Sql Server 2000附加数据库出现1813错误的解决方法 今天进行了一错误操作。 数据库xxzx_discuz,因生成大量日志使日志文件'xxzx_discuz_Log.LDF' 占满了磁盘所有空间,使网站无法正常使用数据库。 自己图省事分离数据库xxzx_discuz后,直接删除'xxzx_discuz_Log.LDF' (因为文件太大,无法存放到回收站),重新附件到SQL Server时出现两个提示: ------------------------------------------------------------------------------------------------------------------------------ SQL Server 企业管理器 --------------------------- 为日志文件指定的文件名不正确。 将创建新的日志文件。 要继续吗? --------------------------- 是(Y) 否(N) ------------------------------------------------------------------------------------------------------------------------------ Microsoft SQL-DMO (ODBC SQLState: 42000) --------------------------- 错误 1813: 未能打开新数据库 'xxzx_discuz'。CREATE DATABASE 将终止。 设备激活错误。物理文件名 'S:Program FilesMicrosoft SQL ServerMSSQLdataxxzx_discuz_Log.LDF' 可能有误。 --------------------------- 确定 ------------------------------------------------------------------------------------------------------------------------------ 从而无法将数据库正常附加到SQL Server 2000,正常情况下这样操作是没有问题的,SQL Server会重新生成日志文件,但是因为之前出现了磁盘空间不足,日志文件不完整,从而造成了无法正常附加。 解决办法如下(从网上找来的): 0.备份数据文件'xxzx_discuz_Log.MDF' 1.新建一个同名的数据库'xxzx_discuz' 2.再停掉sqlserver服务(注意不要分离数据库) 3.用原数据库的数据文件'xxzx_discuz_Log.MDF' 覆盖掉新建的数据库 4.再重启sqlserver服务 5.此时打开企业管理器时会出现置疑,先不管,执行下面的语句(注意修改其中的数据库名) 6.完成后一般就可以访问数据库中的数据了。这时,数据库本身一般还有问题,解决办法是:利用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了. SQL代码 复制代码 代码如下: use master go sp_configure 'allow updates',1 reconfigure with override go update sysdatabases set status =32768 where go sp_dboption '置疑的数据库名', 'single user', 'true' go dbcc checkdb('置疑的数据库名') go update sysdatabases set status =28 where go sp_configure 'allow updates', 0 reconfigure with override go sp_dboption '置疑的数据库名', 'single user', 'false' go 特别注意最后一步中的说明“这时,数据库本身一般还有问题,解决办法是:利用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了” 参考文章:Sql Server附加数据库出现1813错误的解决方法 (编辑:应用网_常德站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server – EXISTS(SELECT 1 …)vs EXISTS(SELECT * …)
- sql-server-2008 – 如何使外键约束受信任?
- sql – 搜索数字是否包含在表达式中:1-3,5,10-15,20
- iis – 如何隐藏DMZ中的连接字符串
- 数据库设计 – 需要数据库设计手册
- sql-server – 无法在计算列上创建筛选索引
- HTML页面源代码布局介绍_动力节点Java学院整理
- sql-server – 用逗号分隔的SQL Server [复制]
- 在SQL中返回空表的首选方法是什么?
- sql-server – SSD(Raid 1)vs SAS(Raid 10)Sql Server硬件推
站长推荐
- sql-server – 如何在SQL Server中为存储过程设置
- R data.table滚动连接“mult”未按预期工作
- 数据库设计 – 需要数据库设计手册
- sql-server – SQL Server HW Config – 您更愿意
- hyper-v – Hyper V 2012和SQL Cluster Live迁移
- SQL查询如果匹配另一个表中的条目(例如假日日期)
- sql-server-2008 – 查看SQL Server代理历史记录
- sql-server – 使用动态sql在指定数据库中创建Vi
- sql-server – 最大连接池上限为100
- sql-server – 增量更新后统计信息消失
热点阅读