求助C#还原数据库
////////数据库换原
private void DataRestore()
{
this.Cursor = Cursors.WaitCursor;
this.lblMessage.Text = " 正在进行数据库的数据还原,这可能需要几秒到几十的时间,请稍候...";
this.lblMessage.Refresh();
this.progressData.Visible = true;
//------------------------------------------------------------------------------------
//string fileName = "Corp_MachineBak";
// string filePath = @System.Windows.Forms.Application.StartupPath+"\\Corp_MachineBak.bak";
string filePath=@"C:\Program Files\Corp_MachineBak.bak";
//string remark = "备份测试";
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
{
oSQLServer.Connect("localhost", "sa", "fly");
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 = "corp_Machine";
oRestore.Files = filePath;
oRestore.FileNumber = 1;
oRestore.ReplaceDatabase = true;
oRestore.SQLRestore(oSQLServer);
}
catch(System.Exception ex)
{
MessageBox.Show("数据还原失败:\n" + ex.ToString());
}
finally
{
oSQLServer.DisConnect();
}
this.Cursor = Cursors.Default;
抛出一个异常,说数据库正在使用,未能获得对数据库的排他访问权``
请问怎么在C#里面控制数据库的排它访问权啊!·