Powershell SMO SQL Server还原问题

问题描述 投票:0回答:1

我在执行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

当我进行此更改时,我开始出现以下错误。

使用“ 1”作为参数调用“ ReadBackupHeader”的异常:“在执行Transact-SQL语句或批处理时发生了异常。”

在线:23个字符:1+ $ smoRestoreDetails = $ smoRestore.ReadBackupHeader($ server)+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~+ CategoryInfo:未指定:(:) [],MethodInvocationException+ FullyQualifiedErrorId:ExecutionFailureException

不太确定为什么它不接受我传递的$ file变量。如果我查看变量,它返回正确的值。

sql-server powershell smo database-restore
1个回答
0
投票

我这是愚蠢的问题。 $ file不包含扩展名。将.bak添加到$ file可以解决此问题。

© www.soinside.com 2019 - 2024. All rights reserved.