顺便稍微散一点分之前的时候想实现远程备份数据库 从网上查资料有人有现成的做法 就是创建作业基本步骤如下所示:
首先要创建映射
第二数据库备份数据
3 把备份文件拷贝到映射的磁盘
4 删除备份的文件
5 断开映射的磁盘
但是当我实验之后发现了一个问题 创建作业之后即使sql server 2005 显示作业执行成功但是真实的情况是 执行到 拷贝这这一环节的时候出现问题 就像断点一样 执行到这一步就再也没有执行 问题就在这里了 作业根本没有完成 但是当我新建查询在查询里边分步执行的时候就会执行完成  试了很多次 最终还是放弃了 前辈们想出来的这种方法 但是 很抱歉的是我这边没法用不知道大家原来是怎么用的 如果有我没有注意到的地方欢迎指正
下午终于决定由C#写一个自动备份的程序  首先using System.Data.sqlclient; 然后尝试在C#下调用dos命令但是发现不等执行完就执行下一步了 所以文件也没有复制过去呀 找了这么一个函数 高手写的 可以设置等待时间 不错的
 /// <summary>
  /// 执行DOS命令,返回DOS命令的输出
  /// </summary>
  /// <param name="dosCommand">dos命令</param>
  /// <param name="milliseconds">等待命令执行的时间(单位:毫秒),如果设定为0,则无限等待</param>
  /// <returns>返回输出,如果发生异常,返回空字符串</returns>
  public static string Execute(string dosCommand, int milliseconds)
  {
  string output = ""; //输出字符串
  if (dosCommand != null && dosCommand != "")
  {
  Process process = new Process(); //创建进程对象
  ProcessStartInfo startInfo = new ProcessStartInfo();
  startInfo.FileName = "cmd.exe"; //设定需要执行的命令
  startInfo.Arguments = "/C " + dosCommand; //设定参数,其中的“/C”表示执行完命令后马上退出
  startInfo.UseShellExecute = false; //不使用系统外壳程序启动
  startInfo.RedirectStandardInput = false; //不重定向输入
  startInfo.RedirectStandardOutput = true; //重定向输出
  startInfo.CreateNoWindow = true; //不创建窗口
  process.StartInfo = startInfo;
  try
  {
  if (process.Start())
  {
  if (milliseconds == 0)
  {
  process.WaitForExit(); //这里无限等待进程结束
  }
  else
  {
  process.WaitForExit(milliseconds); //这里等待进程结束,等待时间为指定的毫秒
  output = process.StandardOutput.ReadToEnd();//读取进程的输出
  }
  }
  }
  catch (Exception)
  {  throw;
  }
  finally
  {
  if (process != null)
  process.Close();
  }
  }
  return output;
  }