J'ai le code suivant :
$DatabaseSettings = @();
$NewDatabaseSetting = "" | select DatabaseName, DataFile, LogFile, LiveBackupPath;
$NewDatabaseSetting.DatabaseName = "LiveEmployees_PD";
$NewDatabaseSetting.DataFile = "LiveEmployees_PD_Data";
$NewDatabaseSetting.LogFile = "LiveEmployees_PD_Log";
$NewDatabaseSetting.LiveBackupPath = '\\LiveServer\LiveEmployeesBackups';
$DatabaseSettings += $NewDatabaseSetting;
Lorsque j'essaie d'utiliser l'une des propriétés d'une commande d'exécution de chaîne de caractères :
& "$SQlBackupExePath\SQLBackupC.exe" -I $InstanceName -SQL `
"RESTORE DATABASE $DatabaseSettings[0].DatabaseName FROM DISK = '$tempPath\$LatestFullBackupFile' WITH NORECOVERY, REPLACE, MOVE '$DataFileName' TO '$DataFilegroupFolder\$DataFileName.mdf', MOVE '$LogFileName' TO '$LogFilegroupFolder\$LogFileName.ldf'"
Il essaie simplement d'utiliser la valeur de $DatabaseSettings
plutôt que la valeur de $DatabaseSettings[0].DatabaseName
, qui n'est pas valide.
Ma solution de contournement est de le faire copier dans une nouvelle variable.
Comment puis-je accéder directement à la propriété de l'objet dans une chaîne entre guillemets ?