Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Per leggere una proprietà differita da un oggetto Gestione configurazione restituito in una query, si ottiene l'istanza dell'oggetto, che recupera tutte le proprietà dell'oggetto lazy dal provider SMS.
Nota
Se si conosce il percorso completo dell'oggetto WMI, una chiamata al metodo GetInstance restituisce l'oggetto WMI insieme alle proprietà lazy. Per altre informazioni, vedere Come leggere un oggetto Gestione configurazione usando codice gestito.
Per altre informazioni, vedere Gestione configurazione Proprietà lazy.
Per leggere le proprietà lazy
Configurare una connessione al provider SMS. Per altre informazioni, vedere Come connettersi a un provider SMS in Gestione configurazione tramite codice gestito.
Utilizzare l'oggetto QueryProcessor per eseguire query su oggetti Gestione configurazione.
Scorrere i risultati della query.
Usando WqlConnectionManager ottenuto nel passaggio 1, chiamare GetInstance per ottenere l'oggetto IResultObject per ogni oggetto sottoposto a query da cui si vogliono ottenere proprietà lazy.
Esempio
Nell'esempio di codice C# seguente vengono eseguite query per tutti gli oggetti SMS_Collection e quindi vengono visualizzati i nomi delle regole ottenuti dalla proprietà differita CollectionRules .
Per informazioni sulla chiamata del codice di esempio, vedere Chiamata di frammenti di codice Gestione configurazione.
public void ReadLazyProperty(WqlConnectionManager connection)
{
try
{
// Query all collections.
IResultObject collections = connection.QueryProcessor.ExecuteQuery("Select * from SMS_Collection");
foreach (IResultObject collection in collections)
{
// Get the collection object and lazy properties.
collection.Get();
Console.WriteLine(collection["Name"].StringValue);
// Get the rules.
List<IResultObject> rules = collection.GetArrayItems("CollectionRules");
if (rules.Count == 0)
{
Console.WriteLine("No rules");
Console.WriteLine();
continue;
}
foreach (IResultObject rule in rules)
{
// Display rule names.
Console.WriteLine("Rule name: " + rule["RuleName"].StringValue);
}
Console.WriteLine();
}
}
catch (SmsQueryException ex)
{
Console.WriteLine("Failed to get collection. Error: " + ex.Message);
throw;
}
}
Questo metodo di esempio include i parametri seguenti:
| Parametro | Tipo | Descrizione |
|---|---|---|
connection |
WqlConnectionManager |
Connessione valida al provider SMS. |
Compilazione del codice
Namespaces
Sistema
System.collections.generic
System.ComponentModel
Microsoft.ConfigurationManagement.ManagementProvider
Microsoft.ConfigurationManagement.ManagementProvider.WqlQueryEngine
Assembly
Microsoft.configurationmanagement.managementprovider
adminui.wqlqueryengine
Programmazione efficiente
Le eccezioni Gestione configurazione che possono essere generate sono SmsConnectionException e SmsQueryException. Questi possono essere intercettati insieme a SmsException.
Vedere anche
proprietà lazy Gestione configurazione
Come chiamare un metodo della classe oggetto Gestione configurazione usando codice gestito
Come connettersi a un provider di Gestione configurazione usando codice gestito
Come creare un oggetto Gestione configurazione usando codice gestito
Come modificare un oggetto Gestione configurazione usando codice gestito
Come eseguire una query Gestione configurazione asincrona usando codice gestito
Come eseguire una query di Gestione configurazione sincrona usando codice gestito
Come leggere un oggetto Gestione configurazione usando codice gestito