Come leggere le proprietà lazy usando codice gestito

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

  1. Configurare una connessione al provider SMS. Per altre informazioni, vedere Come connettersi a un provider SMS in Gestione configurazione tramite codice gestito.

  2. Utilizzare l'oggetto QueryProcessor per eseguire query su oggetti Gestione configurazione.

  3. Scorrere i risultati della query.

  4. 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

Panoramica sugli oggetti

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