Изменить путь к источнику данных подключения для Табличной базы данных - PullRequest
0 голосов
/ 28 июня 2018

Я пытаюсь изменить путь к источнику данных подключения для MSSQL 2017. Мой код:

$ServerName="localhost\olap17"
$loadInfo = [Reflection.Assembly]::LoadWithPartialName("Microsoft.AnalysisServices")

$server = New-Object Microsoft.AnalysisServices.Server
$server.connect($ServerName)
if ($server.name -eq $null) {
 Write-Output ("Server '{0}' not found" -f $ServerName)
 break
}
foreach ($dbase in $server.Databases )
{
Write-Output ( "Database: {0}; Status: {1}; Size: {2}MB; Data Sources: {3} " -f $dbase.Name, $dbase.State, ($dbase.EstimatedSize/1024/1024).ToString("#,##0"), $dbase.Model.DataSources.Count )
foreach ($dsource in $dbase.Model.DataSources)
{
    $dsource.ConnectionDetails.Address.Path = $dsource.ConnectionDetails.Address.Path.Replace('OLDSERVER', 'NEWSERVER')
    echo ">>> Datasource: " $dsource.ConnectionDetails.ToString()
}
}

Вывод отображается правильно, но когда я проверяю свойства соединения, я вижу путь без изменений:

Database: Billing Cycle Delivery; Status: Unprocessed; Size: 0MB; Data Sources: 5 
Datasource: 
{
"protocol": "file",
"address": {
"path": "\\\\NEWSERVER\\Telco\\Models\\Billing Cycle Delivery\\Data Sources\\Billing.xlsx"
},
"authentication": null,
"query": null
}

Похоже, новые свойства не передаются обратно на сервер ... Где моя проблема? Я не могу найти какую-либо полезную информацию в Интернете: (

Любые идеи приветствуются!

1 Ответ

0 голосов
/ 28 июня 2018

Я нашел решение. Необходимо:

$dbase.Update(1)

Это необходимо для отправки изменений на сервер.

Мой последний сценарий, если кому-то нужно:

$changeSource = 'OLDSERVER'
$changeTarget = 'NEWSERVER'
$ServerName="localhost\olap17"
$loadInfo = [Reflection.Assembly]::LoadWithPartialName("Microsoft.AnalysisServices")
$server = New-Object Microsoft.AnalysisServices.Server
$server.connect($ServerName)
if ($server.name -eq $null) {
 Write-Output ("Server '{0}' not found" -f $ServerName)
 break
}
foreach ($dbase in $server.Databases )
{
 Write-Output ( "Database: {0}; Status: {1}; Size: {2}MB; Data Sources: {3} " -f $dbase.Name, $dbase.State, ($dbase.EstimatedSize/1024/1024).ToString("#,##0"), $dbase.Model.DataSources.Count )
 foreach ($dsource in $dbase.Model.DataSources)
 {
    $dsource.ConnectionDetails.Address.Path = $dsource.ConnectionDetails.Address.Path.Replace($changeSource, $changeTarget)
    echo ">>> Datasource name: " $dsource.Name " Connection: " $dsource.ConnectionDetails.ToString()
    $dbase.Update(1)
}
}
$server.Disconnect($ServerName)
echo "Connection closed"
echo "------------- Confirmation --------------"
$server.connect($ServerName)
foreach ($dbase in $server.Databases )
{
 Write-Output ( "Database: {0}; Status: {1}; Size: {2}MB; Data Sources: {3} " -f $dbase.Name, $dbase.State, ($dbase.EstimatedSize/1024/1024).ToString("#,##0"), $dbase.Model.DataSources.Count )
 foreach ($newds in $dbase.Model.DataSources)
 {
    echo ">>> Datasource name: " $newds.Name " Connection: " $newds.ConnectionDetails.ToString()
 }
}
$server.Disconnect($ServerName)

Вот статья MS, которая мне помогает: https://docs.microsoft.com/en-us/dotnet/api/microsoft.analysisservices.database?redirectedfrom=MSDN&view=sqlserver-2016

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...