小编egh*_*tto的帖子

使用Powershell更改SSRS报告的数据源

我正在尝试使用Powershell将多个SSRS报告的数据源改为我的报告服务器上的一个共享数据源.这是我的代码:

cls;  
$reportserver = "myServer";<br/>
$url = "http://$($reportserver)/reportserver/reportservice2005.asmx?WSDL";";<br/>
$ssrs = New-WebServiceProxy -uri $url -UseDefaultCredential -Namespace "ReportingWebService";

[ReportingWebService.DataSource[]] $myDataSource = new-object ReportingWebService.DataSource
$myDataSource[0].Name = "myDS"";<br/>
$myDataSource[0].Item = New-Object ReportingWebService.DataSourceReference<br/>
$myDataSource[0].Item.Reference = "/Data Sources/MyDS"<br/>

$reports = $ssrs.ListChildren('/DH', $false)

$reports | ForEach-Object {<br/>
$reportPath = $_.path<br/>
 Write-Host "Report: " $reportPath<br/>
 $dataSources = $ssrs.GetItemDataSources($reportPath)<br/>
 $dataSources | ForEach-Object {<br/>
              Write-Host "Old source: $($_.Name), $($_.Item.ConnectString)"<br/>
              $ssrs.SetItemDataSources($reportPath, $myDataSource)<br/>
              Write-Host "New source: $($_.Name), $($_.Item.ConnectString)"<br/>
          }<br/>

 Write-Host "------------------------"
}
Run Code Online (Sandbox Code Playgroud)

但是在调用"SetItemDataSources"时遇到以下错误 - 方法:

***Argument "1" having the value "ReportingWebService.DataSource[]" of …
Run Code Online (Sandbox Code Playgroud)

powershell datasource reportingservices-2005

9
推荐指数
2
解决办法
2万
查看次数