Проблема с восстановлением Powershell SMO SQL Server - PullRequest
0 голосов
/ 29 октября 2019

У меня проблема с восстановлением Powershell SQL. У меня есть этот код

[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.SMO") | Out-Null
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.SmoExtended") | Out-Null
[Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.ConnectionInfo") | Out-Null
[Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.SmoEnum") | Out-Null

$backupFile = 'C:\Temp\User_20191029152532.bak'

$server = New-Object ("Microsoft.SqlServer.Management.Smo.Server") "(local)"
$backupDevice = New-Object("Microsoft.SqlServer.Management.Smo.BackupDeviceItem") ($backupFile, "File")
$smoRestore = new-object("Microsoft.SqlServer.Management.Smo.Restore")

$smoRestore.NoRecovery = $false;
$smoRestore.ReplaceDatabase = $true;
$smoRestore.Action = "Database"
$smoRestorePercentCompleteNotification = 10;
$smoRestore.Devices.Add($backupDevice)

$smoRestoreDetails = $smoRestore.ReadBackupHeader($server)

"Database Name from Backup Header : " +$smoRestoreDetails.Rows[0]["DatabaseName"]

$smoRestore.Database =$smoRestoreDetails.Rows[0]["DatabaseName"]

$smoRestoreFile = New-Object("Microsoft.SqlServer.Management.Smo.RelocateFile")
$smoRestoreLog = New-Object("Microsoft.SqlServer.Management.Smo.RelocateFile")

$smoRestoreFile.LogicalFileName = $smoRestoreDetails.Rows[0]["DatabaseName"]
$smoRestoreFile.PhysicalFileName = $server.Information.MasterDBPath + "\" + $smoRestore.Database + "_Data.mdf"
$smoRestoreLog.LogicalFileName = $smoRestoreDetails.Rows[0]["DatabaseName"] + "_Log"
$smoRestoreLog.PhysicalFileName = $server.Information.MasterDBLogPath + "\" + $smoRestore.Database + "_Log.ldf"
$smoRestore.RelocateFiles.Add($smoRestoreFile)
$smoRestore.RelocateFiles.Add($smoRestoreLog)

$smoRestore.SqlRestore($server)

Все отлично работает, если я запускаю это. Тем не менее, я хотел бы предоставить переменную для восстановления резервной копии. Поэтому я изменил верхнюю часть кода следующим образом:

$path = 'C:\Temp'
$db_name = 'User'
$file = Get-ChildItem $path '*.bak' | Select-Object basename | Where-Object {$_.basename -like $db_name + '*' }

$backupFile = $path + '\' + $file

Когда я внесу это изменение, я получу сообщение об ошибке ниже.

Исключение вызывает "ReadBackupHeader" с "1 "аргумент (ы):" Возникла исключительная ситуация при выполнении оператора или пакета Transact-SQL. "

В строке: 23 символа: 1
+ $ smoRestoreDetails = $ smoRestore.ReadBackupHeader ($ server)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo: NotSpecified: (:) [], MethodInvocationException
+ FullyQualifiedErrorId: ExecutionFailureException

Не совсем уверен, почему он не примет переменную $ file, которую я передаю. Если я смотрю на переменную, она возвращает правильное значение.

1 Ответ

0 голосов
/ 30 октября 2019

Глупый вопрос с моей стороны. $ file не включает расширение. Добавление .bak в файл $ решило проблему.

...