一个网页访问Sql一个数据库A,关闭该页后,另一页面运行SqlDataSource.SelectCommand还原数据库A,VS.net 2005提示因为数据库正在使用,所以无法获得对数据库的独占访问权。RESTORE DATABASE 正在异常终止。除了重新启动服务器外还有什么程序上的方法解决吗?十分感谢!!!!!

解决方案 »

  1.   

    做 RESTORE DATABASE 操作,那你得先看看你的数据库链接
    如果链接中连接的数据库是A,而你要做 RESTORE DATABASE A 的话,肯定会出现你所提到的问题
    这样修改 USE Master;RESTORE DATABASE A
      

  2.   

    先:
    backup database 数据库名 to disk='f:\aa'然后:分离数据库,删除数据库文件最后:
    create database 数据库名
    gorestore database 数据库名 from disk='f:\aa'
      

  3.   

    yistudio(阳光灿烂的日子)的方法在SqlServer里可以,但用ASP.net的SqlDataSource处理的网页不成功。只有重启服务才可以。
      

  4.   

    天阿!你们都不知道?还原数据库前要先杀死正在使用数据库得线程CREATE proc killspid (@dbname varchar(20))
    as
    begin
    declare @sql nvarchar(500)
    declare @spid int--SPID 值是当用户进行连接时指派给该连接的一个唯一的整数
    set @sql='declare getspid cursor for 
    select spid from sysprocesses where dbid=db_id('''+@dbname+''')'
    --sysprocesses 包含有关 SQL Server 进程的信息。
    exec (@sql)
    open getspid
    fetch next from getspid into @spid
    while @@fetch_status<>-1--如果FETCH 语句没有执行失败或此行不在结果集中。
    begin
    exec('kill '+@spid)--终止正常连接
    fetch next from getspid into @spid
    end
    close getspid
    deallocate getspid
    end
    GO
      

  5.   

    还原数据前要先关闭和本数据库相关的所有进程.如 winner2050(winner)所说.
    以前我们用SQLDMO做的,你可以参考一下:
    #region 还原数据库
    private void btnRestoreDB_Click(object sender, System.EventArgs e)
    {
    string path     = null;
    string server   = cmbServer.Text.Trim();
    string name     = txtName.Text.Trim();
    string pwd      = txtPassword.Text.Trim();
    string database = cmbDatabase.Text.Trim(); openFileDialog1.Filter           = "数据库备份文件|*.bak|所有文件|*.*";
    openFileDialog1.FilterIndex      = 1;
    openFileDialog1.InitialDirectory = Application.StartupPath;
    openFileDialog1.RestoreDirectory = true;

    if(openFileDialog1.ShowDialog() == DialogResult.OK)
    {
    path = openFileDialog1.FileName;
    } if(path == null || path.Trim() == "") return; this.pBar1.Visible = true; SQLDMO.Restore oRestore     = new SQLDMO.RestoreClass();
    SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
    oRestore.Action = 0 ; 
    SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step); 
    oRestore.PercentComplete += pceh; 
    try
    {
    if(this.rdWindow.Checked)//用Windows身份验证明
    {
    oSQLServer.LoginSecure = true;
    oSQLServer.Connect(null,null,null) ;
    }
    else//用SQL Server中的用户登录
    {
    oSQLServer.LoginSecure = false;
    oSQLServer.Connect(server,name,pwd);
    } SQLDMO.QueryResults qr = oSQLServer.EnumProcesses(-1) ; 
    int iColPIDNum = -1 ; 
    int iColDbName = -1 ; 
    //杀死其它的连接进程
    for(int i=1;i<=qr.Columns;i++) 

    string strName = qr.get_ColumnName(i) ; 
    if (strName.ToUpper().Trim() == "SPID") 

    iColPIDNum = i ; 

    else if (strName.ToUpper().Trim() == "DBNAME") 

    iColDbName = i ; 

    if (iColPIDNum != -1 && iColDbName != -1) 
    break ; 

    for(int i=1;i<=qr.Rows;i++) 

    int    lPID      = qr.GetColumnLong(i,iColPIDNum) ; 
    string strDBName = qr.GetColumnString(i,iColDbName);  if (strDBName.ToUpper() == "CgRecord".ToUpper()) 
    oSQLServer.KillProcess(lPID) ; 
    }  oRestore.Action          = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
    oRestore.Database        = database;
    oRestore.Files           = path;
    oRestore.FileNumber      = 1;
    oRestore.ReplaceDatabase = true;
    oRestore.SQLRestore(oSQLServer);                            
    }
    catch(System.Exception ex)
    {
    throw new Exception("数据还原失败:\n" + ex.ToString());
    }
    finally
    {
    oRestore = null;
    oSQLServer.DisConnect();
    oSQLServer = null;
    } MessageBox.Show("数据库恢复成功!","恢复数据库完成",MessageBoxButtons.OK,MessageBoxIcon.Information); }
    #endregion