首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用PowerShell远程运行的SSIS包脚本编写

用PowerShell远程运行的SSIS包脚本编写
EN

Stack Overflow用户
提问于 2014-11-04 13:11:56
回答 1查看 1K关注 0票数 1

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

我知道如果我使用invoke-命令,DTExec是一种选择,但如果可能的话,我不想这样做,有时可能有多个连接,而且我在某些盒子上看到了崩溃,并多次执行DTExec。

我尝试从包中获取执行脚本,并将其放入PowerShell中,并将其用作SQL查询,我长期担心的是,如果包发生了变化,那么我需要跟踪它。

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

代码语言:javascript
复制
[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

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

EN

回答 1

Stack Overflow用户

发布于 2015-08-25 11:59:36

最后,通过使用sqlcmd并将各个任务转换为Jobs,然后使用sqlcmd执行作业,从而解决了这一问题。

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

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

这允许我访问并提供了一些关于结果的输出,

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26736019

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档