如何解决从SQL Job
我有一个正在数据库服务器上运行的SQL作业,它在调用应用程序服务器以运行exe“ cmd Exec步骤类型”的步骤之一上运行
exe应用程序“ C#”被正确调用并完成所有预期的任务,最后一步,它运行cmd.exe来合并几个文件。
**手动运行exe应用程序时,它可以按预期运行,但是通过SQL Job调用时,它返回以下错误:
Error in MergeFiles() Method : System.ComponentModel.Win32Exception (0x80004005): The directory name is invalid
at System.Diagnostics.Process.StartWithCreateProcess(ProcessStartInfo startInfo)
at System.Diagnostics.Process.Start()
at System.Diagnostics.Process.Start(ProcessStartInfo startInfo)
at _700CreditBillingScheduler.Billing700C.MergeFilesInPath()
值得一提的是,一切都在E:\驱动器上运行
这是我的代码:
string filePath = "E:\\HomeFolder\\ApplicationFolder"; // where merged file will be created
string sourcePath = "E:\\HomeFolder\\ApplicationFolder\\Transaction.Indiv.Files\\*.csv"; // to be merged
string commandLine = String.Format("/c copy /b {0} {1}",sourcePath,"mergedFileName");
var cmd = new ProcessStartInfo("cmd.exe",commandLine);
cmd.WorkingDirectory = filePath;
cmd.UseShellExecute = false;
Process.Start(cmd);
解决方法
尝试删除指定工作目录的行吗?
,我发现了问题,这与UNC路径有关。 该命令试图使用文件的UNC路径合并DB Server上的文件,而cmd.exe不支持UNC,因此该命令在不存在该目录的DB Server上运行。
我切换为使用C#应用程序本身在应用程序服务器上合并文件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。