Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/powershell/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
编写SSIS包脚本以使用PowerShell远程运行_Powershell_Ssis - Fatal编程技术网

编写SSIS包脚本以使用PowerShell远程运行

编写SSIS包脚本以使用PowerShell远程运行,powershell,ssis,Powershell,Ssis,我正在尝试远程运行安装在数据库上的一些SSIS包,我确实可以访问数据库,并且可以查看SSIDB及其目录。我一直面临的问题是如何最好地执行目录中项目中的一个包 如果我使用invoke命令,我知道DTExec是一个选项,但如果可能的话,我不想这样做,有时可能会有多个连接,并且我看到在某些框上多次执行DTExec会导致崩溃 我曾尝试从包中获取执行脚本,并将其放入PowerShell中,并将其用作SQL查询,我长期以来对这种方法的担心是,如果包发生更改,那么我需要跟踪它 我想要的最简单的解决方案是只按名

我正在尝试远程运行安装在数据库上的一些SSIS包,我确实可以访问数据库,并且可以查看SSIDB及其目录。我一直面临的问题是如何最好地执行目录中项目中的一个包

如果我使用invoke命令,我知道DTExec是一个选项,但如果可能的话,我不想这样做,有时可能会有多个连接,并且我看到在某些框上多次执行DTExec会导致崩溃

我曾尝试从包中获取执行脚本,并将其放入PowerShell中,并将其用作SQL查询,我长期以来对这种方法的担心是,如果包发生更改,那么我需要跟踪它

我想要的最简单的解决方案是只按名称执行包,如果我需要更新比每个包的整个SQL脚本更简单的名称的话。这种更简单的解决方案是否可行?最好的方法是什么?到目前为止,我还没有运气运行作为执行与SMO。我试过的是:

[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.SMO") | out-null
$SMOserver = New-Object ('Microsoft.SqlServer.Management.Smo.Server') -argumentlist $Server

#This sets the connection to mixed-mode authentication
$SMOserver.ConnectionContext.LoginSecure=$true

$query = @" this is where my execute SQL goes from the SSIS catalog "@

$db2 = New-Object ('Microsoft.SqlServer.Management.Smo.Database')
$db2 = $SMOserver.Databases[$database]
Write-Host "My Query: $query"
$results2 = $db2.ExecuteNonQuery($query)
Write-Host "Results: " $results2

虽然当我运行它时,我通常只得到一个返回值,没有任何值。

最终通过使用sqlcmd将单个任务转换成作业,然后使用sqlcmd执行作业来解决这个问题

因此,使用用户名和密码:

$jobOutput=sqlcmd-S$server-U$username-p$password-Q“EXEC msdb.dbo.sp_start_job@job_name=N'$jobName'”

这允许访问并为我提供了一些结果输出