Мне нужно создать функцию PowerShell с динамическими параметрами, которые зависят друг от друга ($ server, $ database, $ table) .
1. When the user picks $server, parameter $database needs to be auto-populated.
2. And, depending on what value selected for $database the $table parameter needs to be auto-populated.
У меня есть код для одного динамического параметра ($ server $ database) здесь . (Это тоже было опубликовано мной, с наградой). Кто-то еще на этом
Форум задал похожий вопрос здесь , но пока никто не ответил.
Вот код для одного динамического параметра:
import-module sqlps
function Get-Database {
<#
.SYNOPSIS
Dynamic validationset of databases
#>
#Requires -Version 3.0
[CmdletBinding()]
Param (
[Parameter(Mandatory)][string]$server
)
DynamicParam {
$newparams = New-Object System.Management.Automation.RuntimeDefinedParameterDictionary
$paramattributes = New-Object System.Management.Automation.ParameterAttribute
$paramattributes.ParameterSetName = "__AllParameterSets"
$paramattributes.Mandatory = $false
$systemdbs = @("master", "msdb", "model", "SSIS", "distribution")
$srv = New-Object 'Microsoft.SqlServer.Management.SMO.Server' "$server"
$dblist = ($srv.Databases).name | Where-Object { $systemdbs -notcontains $_ }
$argumentlist = @()
foreach ($db in $dblist) {
$argumentlist += [Regex]::Escape($db)
}
$validationset = New-Object System.Management.Automation.ValidateSetAttribute -ArgumentList $argumentlist
$combinedattributes = New-Object -Type System.Collections.ObjectModel.Collection[System.Attribute]
$combinedattributes.Add($paramattributes)
$combinedattributes.Add($validationset)
$Databases = New-Object -Type System.Management.Automation.RuntimeDefinedParameter("Databases", [String[]], $combinedattributes)
$newparams.Add("Databases", $Databases)
return $newparams
}
process {
$UserDb = $psboundparameters.Databases
Write-Host "You picked: $UserDb"
}
}
Clear-Host
Get-Database -server 'YourServerName' -Databases 'DynamicallyPopulatedDatabases'