远程范围到本地

时间:2015-12-06 18:24:20

标签: powershell variables global-variables local

非常感谢@brianlist,我已经尝试了你的建议,当我将它与批量复制一起使用时,它给了我这个错误,不确定该值是否已传递给$value

Cannot convert argument "0", with value: "System.Object[]", for "WriteToServer"
to type "System.Data.DataRow[]": "Cannot convert the "System.Data.DataRow" value
of type "Deserialized.System.Data.DataRow" to type "System.Data.DataRow"."
At C:\test\modified.ps1:11 char:24
+ $bulkCopy.WriteToServer <<<< ($value)
    + CategoryInfo          : NotSpecified: (:) [], MethodException
    + FullyQualifiedErrorId : MethodArgumentConversionInvalidCastArgument
Get-Content 'C:\test\computers.txt' | ? { $_.trim() -ne "" } | ForEach-Object {
    $value =  Invoke-Command -Computer $_ -ScriptBlock {
        Param($computer)
        #..
        $SqlAdapter = New-Object System.Data.SqlClient.SqlDataAdapter
        $global:mdtable = New-Object System.Data.DataTable
        $SqlAdapter.SelectCommand = $SqlCmd
        $nRecs = $SqlAdapter.Fill($mdtable)
        $mdtable
    } -ArgumentList $_ -Credential $cred 
} | test

Function test {
    $Database = 'Test1'
    $table = 'dbo.table_2'
    $connectionstring = "Data Source=mylocal;Integrated Security=True;Initial Catalog=$Database"
    $Conn  = New-Object System.Data.SqlClient.SQLConnection($connectionstring)
    $conn.open()
    $bulkcopy = New-Object Data.SqlClient.SqlBulkCopy($conn)
    $bulkcopy.DestinationTableName = $table
    $bulkCopy.WriteToServer($value)
    $conn.close()
}

1 个答案:

答案 0 :(得分:4)

您已经从$mdtable脚本块返回Invoke-Command的值。要获得除此之外的值,只需将Invoke-Command的结果与变量对齐:

Get-Content 'C:\test\computers.txt'| ? {$_.trim() -ne "" } | ForEach-object{
    $value = Invoke-Command -Computer $_ -ScriptBlock {
        Param($computer)
        # ...
        $mdtable
    }

在此示例中,$value将包含$mdtable所拥有的内容。