0
$from
からバージョンにデータベースを更新するには、dacservice.deploy
を実行する必要があります。ここに私のPSスクリプトは次のとおりです。現在dacService.Deploy
はいくつかの理由のために並列に実行されているpowershell:シーケンス内で複数のdacservice.deploy呼び出しを実行する方法
#deploy
For ($i=$from; $i -le $to; $i++) {
$dacpacFileName = $dacpacPathName + $i + '.dacpac'
Write-Output "-----------------------------------------------------------------------"
Write-Output "Deploying... $dacpacFileName to $databaseServerName\$targetDatabaseName"
Write-Output "-----------------------------------------------------------------------"
#dacpac
$dp = [Microsoft.SqlServer.Dac.DacPackage]::Load($dacpacFileName)
#options
$options = New-Object Microsoft.SqlServer.Dac.DacDeployOptions
$options.GenerateSmartDefaults="True"
$options.BlockOnPossibleDataLoss="False"
$options.IncludeTransactionalScripts = "True"
#deploy
$dacService.Deploy($dp, $targetDatabaseName, $upgradeExisting, $options)
}
。とにかく
一つ一つを実行するように依頼しますか?
PS:私はsqlPackage.exe
で行うことができます。
#deploy
For ($i=$from; $i -le $to; $i++) {
$dacpacFileName = $dacpacPathName + $i + '.dacpac'
Write-Output "-----------------------------------------------------------------------"
Write-Output "Deploying... $dacpacFileName to $databaseServerName\$targetDatabaseName"
Write-Output "-----------------------------------------------------------------------"
& $sqlPackageExePath /a:Publish /sf:$dacpacFileName /tdn:$targetDatabaseName /TargetServerName:$databaseServerName /p:GenerateSmartDefaults=true
Write-host "Finished"
}