• 全部
  • .NET Framework
  • ASP
  • Web Services
  • .NET互联网桌面应用
  • VB
  • 图表区
  • 分析与设计
  • 组件/控件开发
  • AppLauncher
  • 问答

数据库恢复????

cjzlxy 2004-10-29 03:22:26
/// <summary>
/// 数据库恢复
/// </summary>
public static void DbRestore()
{
SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
try
{
oSQLServer.LoginSecure = false;
oSQLServer.Connect("localhost", "sa", "1234");
oRestore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
oRestore.Database = "Northwind";
oRestore.Files = @"d:\Northwind.bak";
oRestore.FileNumber = 1;
oRestore.ReplaceDatabase = true;
oRestore.SQLRestore(oSQLServer);
}
catch
{
throw;
}
finally
{
oSQLServer.DisConnect();
}

************************
返回信息:
[Microsoft][ODBC SQL Server Driver][SQL Server]因为数据库正在使用,所以未能获得对数据库的排它访问权。 [Microsoft][ODBC SQL Server Driver][SQL Server]RESTORE DATABASE 操作异常终止。

怎么解决??????????/
...全文
67 点赞 收藏 9
写回复
9 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
cjzlxy 2004-10-29
问题我自己解决了.谢谢各位帮助.马上揭帖,顺便吧答案贴出来.
1.首先建立存储过程(杀死访问数据库的进程)
CREATE PROCEDURE killspid @dbname varchar(20)
as
begin
declare @sql nvarchar(500),@temp varchar(1000)
declare @spid int
set @sql='declare getspid cursor for
select spid from master..sysprocesses where dbid=db_id('''+@dbname+''')'
exec (@sql)
open getspid
fetch next from getspid into @spid
while @@fetch_status <> -1
begin
set @temp='kill '+rtrim(@spid)
exec(@temp)
fetch next from getspid into @spid
end
close getspid
deallocate getspid
end
GO
2.执行此存储过程
3.恢复数据库(上面的代码)
ok.
回复
cjzlxy 2004-10-29
自己up
回复
cjzlxy 2004-10-29
各位老大,能不能来点实际的,理论上我知道怎么弄,现在遇到的问题是怎么样锁定数据库,杀死所有访问数据库的进程?
回复
reddg 2004-10-29
用DMO重启sql server服务
回复
cjzlxy 2004-10-29
To:xiaohutushen(xiaohutushen)
怎么锁定数据库?
回复
cjzlxy 2004-10-29
这么写对吗?
"data source=localhost;database=master;user id=sa;password=123456"
回复
xiaohutushen 2004-10-29
你恢复的时间要确保只有你一个人用数据库啊。
先锁定数据库。在恢复
帮忙UP
回复
cjzlxy 2004-10-29
To: 楼上:
"链接字符串修改为链接系统数据库
不要链接你要恢复的数据库"

具体怎么写?
回复
standy 2004-10-29
链接字符串修改为链接系统数据库
不要链接你要恢复的数据库
回复
发帖
.NET技术社区
创建于2007-09-28

5.8w+

社区成员

.NET技术交流专区
申请成为版主
帖子事件
创建了帖子
2004-10-29 03:22
社区公告
暂无公告