1

我正在尝试使用以下代码片段执行命令:

foreach($package in (Get-Childitem *.dtsx | select-object -expand Name))
{
    DTUTIL /COPY SQL;"\$package" /DESTSERVER "$global:SSISServer" /FILE "$package" /Q
}

但是,这样做会导致以下错误消息:

You must provide a value expression on the right-hand side of the '/' operator.
At C:\Projects\RiskOptix\Code\Deployment\BuildAll.ps1:267 char:39
+         DTUTIL /COPY SQL;"\$package" / <<<< DESTSERVER "$global:SSISServer" /FILE "$package" /Q
+ CategoryInfo          : ParserError: (:) [], ParentContainsErrorRecordException
+ FullyQualifiedErrorId : ExpectedValueExpression

我也试过

& DTUTIL "/COPY SQL;'\" + [System.IO.Path]::GetFileNameWithoutExtension($package) + "' /DESTSERVER '$global:SSISServer' /FILE $package"

但现在这给了我

Microsoft (R) SQL Server SSIS Package Utilities
Version 10.50.1600.1 for 32-bit
Copyright (C) Microsoft Corporation 2010. All rights reserved.

At least one of the DTS, SQL, or File options must be specified.

但至少命令运行了,但它似乎没有收到我发送给它的任何参数......我猜我在这里忽略或未能掌握 PowerShell 的基本概念。我哪里出错了?

4

2 回答 2

1

试试看Invoke-Expression

Invoke-Expression "DTUTIL /COPY SQL;`"\$package`" /DESTSERVER `"$global:SSISServer`" /FILE `"$package`" /Q"

首先评估整个字符串,然后像普通命令一样将结果传递给powershell

于 2012-06-08T20:12:43.350 回答
1

将变量作为参数传递给命令时,不需要引用它们。话虽如此,看起来您的命令中有一个流氓分号。分号在 PowerShell 中是可选的,但如果存在,则用作命令分隔符。在这种情况下,您需要引用带有分号的参数,或者为该参数创建一个变量:

Get-Childitem *.dtsx | 
    Select-Object -expand Name |
    ForEach-Object { DTUTIL /COPY "SQL;\$package" /DESTSERVER $global:SSISServer /FILE $package /Q

我从来没有使用过diutil,所以不知道命令参数或语法。

于 2012-06-09T23:09:35.637 回答