SQLDMO.Backup oBackup = new SQLDMO.BackupClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
try
{
oSQLServer.LoginSecure = false;
oSQLServer.Connect("localhost","sa","sa");
oBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
oBackup.Database = "bb";
string NowPath;
NowPath = System.Environment.CurrentDirectory;
string BackFile;
string TimeFileName;
       TimeFileName = DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() +    DateTime.Now.Day.ToString() +  "_" + DateTime.Now.Hour.ToString() + 
DateTime.Now.Minute.ToString() + ".bak"; BackFile = @NowPath + "\\DataBackUp\\" + TimeFileName ;
oBackup.Files = BackFile;oBackup.BackupSetName = "bb";
oBackup.BackupSetDescription = "数据库备份";
oBackup.Initialize = true;
oBackup.SQLBackup(oSQLServer);
}
catch
{
throw;
}
finally
{
oSQLServer.DisConnect();
}
NowPath里我存放的是系统进程从中启动的目录(及bin\Debug\DataBackUp目录),
但运行时BackFile = @NowPath + "\\DataBackUp\\" + TimeFileName这句出错,
而问题就出在NowPath变量里, 
请教朋友们该如何解决!!!!
小弟谢谢各位朋友

解决方案 »

  1.   

    CS个还是BS???
    fileName = Application.StartupPath
      

  2.   

    这是个单机程序!
    bin\Debug\DataBackUp目录是运行程序时自动创建的目录自己帮自己顶一下 
    继续关注!!!!!
      

  3.   

    我连了数据库,它居然提示‘未能与信任的数据库建立连接’:我超级用户根本就没设置密码。。数据库登陆是WINDOWS身份验证是什么原因?
      

  4.   

    是不是数据恢复要关闭SQL的所有进程啊
    请问进程该如何关闭啊
    请路过的朋友帮助一下谢谢
      

  5.   

    方法一(不使用SQLDMO):
    ///
    ///备份方法
    ///
    SqlConnection conn = new SqlConnection("Server=.;Database=master;User ID=sa;Password=sa;");

    SqlCommand cmdBK = new SqlCommand();
    cmdBK.CommandType = CommandType.Text;
    cmdBK.Connection = conn;
    cmdBK.CommandText = @"backup database test to disk='C:\Documents and Settings\gyj\桌面\ba' with init"; try
    {
    conn.Open();
    cmdBK.ExecuteNonQuery();
    MessageBox.Show("Backup successed.");
    }
    catch(Exception ex)
    {
    MessageBox.Show(ex.Message);
    }
    finally
    {
    conn.Close();
    conn.Dispose();
    }
            ///
    ///还原方法
    ///
    SqlConnection conn = new SqlConnection("Server=.;Database=master;User ID=sa;Password=sa;Trusted_Connection=False");
    conn.Open(); //KILL DataBase Process
    SqlCommand cmd = new SqlCommand("SELECT spid FROM sysprocesses ,sysdatabases WHERE sysprocesses.dbid=sysdatabases.dbid AND sysdatabases.Name='test'", conn);
    SqlDataReader dr;
    dr = cmd.ExecuteReader();
    ArrayList list = new ArrayList();
    while(dr.Read())
    {
    list.Add(dr.GetInt16(0));
    }
    dr.Close();
    for(int i = 0; i < list.Count; i++)
    {
    cmd = new SqlCommand(string.Format("KILL {0}", list[i]), conn);
    cmd.ExecuteNonQuery();
    } SqlCommand cmdRT = new SqlCommand();
    cmdRT.CommandType = CommandType.Text;
    cmdRT.Connection = conn;
    cmdRT.CommandText = @"restore database test from disk='C:\Documents and Settings\gyj\桌面\ba'"; try
    {
    cmdRT.ExecuteNonQuery();
    MessageBox.Show("Restore successed.");
    }
    catch(Exception ex)
    {
    MessageBox.Show(ex.Message);
    }
    finally
    {
    conn.Close();
    }
     方法二(使用SQLDMO):
    ///
    ///备份方法
    ///
    SQLDMO.Backup backup = new SQLDMO.BackupClass();
    SQLDMO.SQLServer server = new SQLDMO.SQLServerClass();
    //显示进度条
    SQLDMO.BackupSink_PercentCompleteEventHandler progress = new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);
    backup.PercentComplete += progress; try
    {
    server.LoginSecure = false;
    server.Connect(".", "sa", "sa");
    backup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
    backup.Database = "test";
    backup.Files = @"D:\test\myProg\backupTest";
    backup.BackupSetName = "test";
    backup.BackupSetDescription = "Backup the database of test";
    backup.Initialize = true;
    backup.SQLBackup(server);
    MessageBox.Show("Backup successed.");
    }
    catch(Exception ex)
    {
    MessageBox.Show(ex.Message);
    }
    finally
    {
    server.DisConnect();
    }
    this.pbDB.Value = 0;



    ///
    ///还原方法
    ///
    SQLDMO.Restore restore = new SQLDMO.RestoreClass();
    SQLDMO.SQLServer server = new SQLDMO.SQLServerClass();
    //显示进度条
    SQLDMO.RestoreSink_PercentCompleteEventHandler progress = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
    restore.PercentComplete += progress; //KILL DataBase Process
    SqlConnection conn = new SqlConnection("Server=.;Database=master;User ID=sa;Password=sa;Trusted_Connection=False");
    conn.Open();
    SqlCommand cmd = new SqlCommand("SELECT spid FROM sysprocesses ,sysdatabases WHERE sysprocesses.dbid=sysdatabases.dbid AND sysdatabases.Name='test'", conn);
    SqlDataReader dr;
    dr = cmd.ExecuteReader();
    ArrayList list = new ArrayList();
    while(dr.Read())
    {
    list.Add(dr.GetInt16(0));
    }
    dr.Close();
    for(int i = 0; i < list.Count; i++)
    {
    cmd = new SqlCommand(string.Format("KILL {0}", list[i]), conn);
    cmd.ExecuteNonQuery();
    }
    conn.Close();

    try
    {
    server.LoginSecure = false;
    server.Connect(".", "sa", "sa");
    restore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
    restore.Database = "test";
    restore.Files = @"D:\test\myProg\backupTest";
    restore.FileNumber = 1;
    restore.ReplaceDatabase = true;
    restore.SQLRestore(server);
    MessageBox.Show("Restore successed.");
    }
    catch(Exception ex)
    {
    MessageBox.Show(ex.Message);
    }
    finally
    {
    server.DisConnect();
    }
    this.pbDB.Value = 0;