【20130321】sql server 2005 之后 文件状态变为了7,DEFUNCT(僵死状态)

简介: 问题:     sql server 2005 之后 文件状态变为了7,DEFUNCT(僵死状态) 问题原因:     一般都是因为一些不合法的操作引起的 如以下: CREATE DATABASE Test GO ALTER DATABASE [Test] ADD FILEGROUP...

问题:

    sql server 2005 之后 文件状态变为了7,DEFUNCT(僵死状态)

问题原因:

    一般都是因为一些不合法的操作引起的 如以下:

CREATE DATABASE Test
GO
ALTER DATABASE [Test] ADD FILEGROUP [TestFG]
GO
ALTER DATABASE [Test] ADD FILE ( NAME = N'TestFile', FILENAME = N'C:\Program Files (x86)\Microsoft SQL Server\MSSQL10_50.SQL2008R2\MSSQL\DATA\TestFile.ndf'
, SIZE = 3072KB , FILEGROWTH = 1024KB ) TO FILEGROUP [TestFG]
GO
--ok at this point you set it offline
ALTER DATABASE Test MODIFY FILE (NAME = TestFile, OFFLINE);SELECT state_desc,* FROM Test.sys.database_files;
GO  
 
ALTER DATABASE Test MODIFY FILE (NAME = TestFile, OFFLINE);
GO
ALTER DATABASE [Test] REMOVE FILEGROUP [TestFG]
GO
ALTER DATABASE [Test]  REMOVE FILE [TestFile]
GO
SELECT state_desc,* FROM Test.sys.database_files;

解决方法:

     使用-m启动服务,使用DAC连接,使用一下代码修改系统表。之前可能要配置 sp_configure 中的 allow update参数。

UPDATE  Test.sys.sysprufiles set filestate  = 6 where fileid = 3;
UPDATE master.sys.sysbrickfiles set filestate  = 6  where dbid = db_id('Test') and fileid = 3;
checkpoint

    正常启动服务,现在文件正处于offline 状态,修改为online,并删除文件和文件组。若数据文件丢失或备份丢失,那么就没办法online了,这个问题还需要深入研究

RESTORE DATABASE test FILE='TestFile' WITH recovery
go
ALTER DATABASE [Test]  REMOVE FILE [TestFile]
go
ALTER DATABASE [Test] REMOVE FILEGROUP [TestFG]
GO

 

目录
相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
SQL 存储 API
Flink实践:通过Flink SQL进行SFTP文件的读写操作
虽然 Apache Flink 与 SFTP 之间的直接交互存在一定的限制,但通过一些创造性的方法和技术,我们仍然可以有效地实现对 SFTP 文件的读写操作。这既展现了 Flink 在处理复杂数据场景中的强大能力,也体现了软件工程中常见的问题解决思路——即通过现有工具和一定的间接方法来克服技术障碍。通过这种方式,Flink SQL 成为了处理各种数据源,包括 SFTP 文件,在内的强大工具。
589 15
|
SQL 关系型数据库 MySQL
数据库导入SQL文件:全面解析与操作指南
在数据库管理中,将SQL文件导入数据库是一个常见且重要的操作。无论是迁移数据、恢复备份,还是测试和开发环境搭建,掌握如何正确导入SQL文件都至关重要。本文将详细介绍数据库导入SQL文件的全过程,包括准备工作、操作步骤以及常见问题解决方案,旨在为数据库管理员和开发者提供全面的操作指南。一、准备工作在导
2257 0
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
SQL 数据库
DBeaver执行sql文件
本文介绍了DBeaver这款支持多种数据库的通用数据库管理工具和SQL客户端,它具备查看数据库结构、执行SQL查询和脚本、浏览和导出数据等功能。
4069 1
DBeaver执行sql文件
|
SQL 关系型数据库 MySQL
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
SQL 数据库
为什么 SQL 日志文件很大,我应该如何处理?
为什么 SQL 日志文件很大,我应该如何处理?
|
SQL 存储 关系型数据库
SQL文件导入MySQL数据库的详细指南
数据库中的数据转移是一项常规任务,无论是在数据迁移过程中,还是在数据备份、还原场景中,导入导出SQL文件显得尤为重要。特别是在使用MySQL数据库时,如何将SQL文件导入数据库是一项基本技能。本文将详细介绍如何将SQL文件导入MySQL数据库,并提供一个清晰、完整的步骤指南。这篇文章的内容字数大约在
1836 1
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
420 1