顺便稍微散一点分之前的时候想实现远程备份数据库 从网上查资料有人有现成的做法 就是创建作业基本步骤如下所示:
首先要创建映射
第二数据库备份数据
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;
}
首先要创建映射
第二数据库备份数据
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;
}
解决方案 »
免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货