MSSQL2005,2000 恢复单个mdf文件【转】

简介: 我把原来的数据库分离后,直接把日志文件给干掉了。原来在SQL 2000里经常这么干,只用一个mdf就附加了。没想到sql2005居然不行。我试验了一圈 终于找到一个成功的方法。转载,供后来者参考。SQL2000 简单一些 1.

我把原来的数据库分离后,直接把日志文件给干掉了。原来在SQL 2000里经常这么干,只用一个mdf就附加了。没想到sql2005居然不行。我试验了一圈 终于找到一个成功的方法。转载,供后来者参考。
SQL2000 简单一些

1.创建数据库
2.覆盖
3.use master
go
sp_configure 'allow updates',1
go
reconfigure with override
go
 
update sysdatabases set status=-32768 where dbid=DB_ID('test')
 
dbcc rebuild_log('test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf')
dbcc checkdb('test')
sp_dboption 'test','dbo use only','false'
 
-----------------------------------------------------------------

SQL2005 如果mdf不存在任何错误可以使用这个方法:

CREATEDATABASE TestDB   
ON   
(   
FILENAME 
='D:\TestDB.mdf'     
for ATTACH_REBUILD_LOG


SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件

第一步:先建立一个同名数据库,停止SQL SERVER2005,将没有日志的的.mdf数据库文件覆盖刚新建的.mdf数据库文件,重新启动数据库。

第三步:在查询分析器中运行如下代码:

alter database 数据库名 set emergency —将数据库设置为紧急状态

use master 

declare @databasename varchar(255) 

set @databasename=‘数据库名’ —你的.mdf文件文件名

exec sp_dboption @databasename, N’single‘, N’true’ —将目标数据库置为单用户状态 

dbcc checkdb(@databasename,REPAIR_ALLOW_DATA_LOSS) 

dbcc checkdb(@databasename,REPAIR_REBUILD) 

exec sp_dboption @databasename, N’single‘, N’false’—将目标数据库置为多用户状态 


执行出现“数据库其他多个文件与数据库主文件不匹配….”错误,再执行一次即可。

目录
相关文章
|
8月前
|
关系型数据库 数据库
Mairadb数据库的备份和恢复
Mairadb数据库的备份和恢复
141 1
|
关系型数据库 数据库 PostgreSQL
PG 数据文件
每个索引和表都是一个单独的文件,page页/段,默认1G,大于1G的page会被分割
257 0
|
关系型数据库 MySQL 数据库
windows mysql5.7 InnoDB 通过frm与ibd对数据进行恢复
参考:https://www.jianshu.com/p/50a2e13cd5cf 安装MySQL Utilities 下载地址:https://dev.mysql.com/downloads/utilities/ 下载完后直接安装即可 如果运行时需要python就下载 https://dev.
3018 0
|
Oracle 关系型数据库 数据库
|
SQL 监控 数据库
sql server数据库文件的迁移(mdf&ldf文件)
sql server数据库文件的迁移(mdf&ldf文件) mssql server数据库文件修改, --查看当前的存放位置   select database_id,name,physical_name AS CurrentLocation,state_desc,size from sys.master_files     where database_id=db_id(N'数据库名');   在服务器不同磁盘目录内做迁移。
1642 0