我有一个需要多个参数的脚本:
param ([string]$FOO="foo",[string]$CFG='\ps\bcpCopyCfg.ps1', [string]$CFROM="none", `
[string]$CTO="none", [switch]$HELP=$FALSE, [switch]$FULL=$FALSE, [string]$CCOL="none" `
,[string]$CDSQUERY="none", [string]$CMSSRV="none" `
,[string]$CSYBDB="none", [string]$CMSDB="none")
当从命令提示符调用时,例如:
powershell .\bcpCopy.ps1 -CFROM earn_n_deduct_actg -CTO fin_earn_n_deduct_actg -CCOL f_edeh_doc_id
一切正常。但是我需要同时启动几个(数十个)脚本实例,并编写了一个包装脚本,将执行实际工作的脚本作为作业调用: 我准备了一个包含参数的数组(包括像“-CFG”这样的关键字),并将其传递给start-job:
# Prepare script block to be released
$ARGS=("-CFG ", $CFG, "-CSYBDB ", $SYBDB, "-CMSDB ",$MSDB, "-CFROM ", $SYBTBL, "-CTO ",$MSTBL)
if ($FULL) {
$ARGS = $ARGS + " -FULL"
} else {
$ARGS = $ARGS + " -CCOL $($args[5]) "
}
"Argument array:"
$ARGS
start-job -scriptblock {powershell.exe -file '\ps\bcpCopy.ps1'} -ArgumentList $ARGS
很不幸,被调用的脚本没有接收到参数:调用者打印出来的数组看起来很好:
参数数组:
-CFG
\ps\bcpCopyCfgOAH.ps1
-CSYBDB
vnimisro
-CMSDB
IMIS_UNOV
-CFROM
earn_n_deduct_ref
-CTO
fin_earn_n_deduct_ref
-FULL
但是被调用脚本的输出表示只有配置文件这一个参数被接收了——其他所有参数都在它们的默认值状态下。
PS C:\ps> receive-job 1391
12/17/2010 10:54:14 开始上传表 none;源数据库 none;
12/17/2010 10:54:14 目标表为 none;目标数据库为 none;
12/17/2010 10:54:14 配置文件是 \ps\bcpCopyCfg.ps1。
12/17/2010 10:54:14 目标服务器(MS SQL)为 secap900-new
12/17/2010 10:54:14 必须指定源数据库。正在退出...
请问我做错了什么?