怎么使用SQLDMO还原数据库并把它移动到 C:\Program Files\Microsoft SQL Server\MSSQL\Data 目录下

txt_ly 2007-09-06 01:03:28
public bool CreateDB(string strDbName, string strFileName)
{

SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass();
try
{
svr.Connect(_ServerName, _UserName, _Password);
SQLDMO.QueryResults qr = svr.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() == strDbName.ToUpper())
svr.KillProcess(lPID);
}

SQLDMO.Restore res = new SQLDMO.RestoreClass();
res.Action = 0;
SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(StepCreateDb);
res.PercentComplete += pceh;
res.Files = strFileName;

res.Database = strDbName;
res.FileNumber = 1;
res.ReplaceDatabase = true;
string mdfFilePath_and_Name = Application.StartupPath + @"\DB\HzxCrm.mdf";
string LogFilePath_and_Name = Application.StartupPath + @"\DB\HzxCrm_log.ldf";
string FileName = "HzxCrm.mdf";
res.RelocateFiles = "[HzxCrm.mdf]" + "," + "[" + mdfFilePath_and_Name + "]" + ",[HzxCrm_log.ldf]" + "," + "[" + LogFilePath_and_Name + "]"; //这句有问题

res.SQLRestore(svr);
MessageBox.Show("创建数据库成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);

return true;
}
catch(Exception EX)
{
MessageBox.Show("创建数据库失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);

return false;
}
finally
{
svr.DisConnect();

}
...全文
170 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
huangbiao1314 2009-12-18
  • 打赏
  • 举报
回复
我也遇到这个问题,知道 了,麻烦转告!崩溃了!!!!
txt_ly 2007-09-06
  • 打赏
  • 举报
回复
也就是这个sql语句的效果
RESTORE DATABASE MyNwind
FROM MyNwind_1
WITH NORECOVERY,
MOVE 'MyNwind' TO 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\NewNwind.mdf',
MOVE 'MyNwindLog1' TO 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\NewNwind.ldf'
RESTORE LOG MyNwind
FROM MyNwindLog1
WITH RECOVERY

txt_ly 2007-09-06
  • 打赏
  • 举报
回复
res.RelocateFiles 应该怎么给它赋值

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧