我已安排一个SQLserver代理作业,该作业执行调用批处理启动的PowerShell脚本。但是,执行PowerShell时,它不会等到批处理文件完成,然后再转到下一个作业步骤。我能做些什么来等待"等待"要在继续之前完成批处理文件?
这是命令:
([WMICLASS]"\\SERVER\ROOT\CIMV2:win32_process").Create("cmd.exe /c E:\BatchFiles\First_Batch_File.bat")
答案 0 :(得分:1)
Create
方法将返回其创建的进程的ProcessId
。您可以使用Get-Process
$process = ([WMICLASS]"\\SERVER\ROOT\CIMV2:win32_process").Create("cmd.exe /c E:\BatchFiles\First_Batch_File.bat")
while ((Get-Process -Id $process.ProcessId -ErrorAction SilentlyContinue) -ne $null) {
write-host "waiting"
sleep 2
}