Anteckning
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
I Configuration Manager använder du metoden ProcessQuery för att utföra en asynkron fråga med hjälp av den hanterade SMS-providern.
Den första parametern för metoden ProcessQuery är en instans av klassen SmsBackgroundWorker som tillhandahåller två händelsehanterare:
QueryProcessObjectReady. Den här händelsehanteraren anropas för varje objekt som returneras av frågan. Händelsehanteraren tillhandahåller ett IResultObject-objekt som representerar objektet.
QueryProcessCompleted. Den här händelsehanteraren anropas när frågan har slutförts. Den innehåller också information om eventuella fel som inträffar. Mer information finns i Information om felhantering finns i Hantera Configuration Manager asynkrona fel med hjälp av hanterad kod.
Den andra parametern för metoden ProcessQuery är WQL-instruktionen för frågan.
Så här utför du en asynkron fråga
Konfigurera en anslutning till SMS-providern. Mer information finns i grunderna för SMS-provider.
Skapa objektet SmsBackgroundWorker och fyll i egenskaperna QueryProcessorObjectReady och QueryProcessorCompleted med namn på återanropsmetod.
Från det WqlConnectionManager-objekt som du får i steg ett anropar du metoden QueryProcessor-objektetProcessQuery för att starta den asynkrona frågan.
Exempel
Följande exempel frågar efter alla tillgängliga SMS_Collection objekt, och i händelsehanteraren skriver exemplet flera av samlingsegenskaperna till Configuration Manager-konsolen.
Information om hur du anropar exempelkoden finns i Anropa Configuration Manager kodfragment.
public void QueryCollections(WqlConnectionManager connection)
{
try
{
// Set up the query.
SmsBackgroundWorker bw1 = new SmsBackgroundWorker();
bw1.QueryProcessorObjectReady += new EventHandler<QueryProcessorObjectEventArgs>(bw1_QueryProcessorObjectReady);
bw1.QueryProcessorCompleted += new EventHandler<RunWorkerCompletedEventArgs>(bw1_QueryProcessorCompleted);
// Query for all collections.
connection.QueryProcessor.ProcessQuery(bw1, "select * from SMS_Collection");
// Pause while query runs.
Console.ReadLine();
}
catch (SmsException ex)
{
Console.WriteLine("Failed to start asynchronous query: ", ex.Message);
}
}
void bw1_QueryProcessorObjectReady(object sender, QueryProcessorObjectEventArgs e)
{
try
{
// Get the collection.
IResultObject collection = (IResultObject)e.ResultObject;
//Display properties.
Console.WriteLine(collection["CollectionID"].StringValue);
Console.WriteLine(collection["Name"].StringValue);
Console.WriteLine();
collection.Dispose();
}
catch (SmsQueryException eX)
{
Console.WriteLine("Query Error: " + eX.Message);
}
}
void bw1_QueryProcessorCompleted(object sender, RunWorkerCompletedEventArgs e)
{
Console.WriteLine("Done...");
}
Den här exempelmetoden har följande parametrar:
Parameter | Typ | Beskrivning |
---|---|---|
connection |
Hanterade: WqlConnectionManager |
En giltig anslutning till SMS-providern. |
Kompilera koden
Namnområden
System
System.Collections.Generic
System.ComponentModel
Microsoft.ConfigurationManagement.ManagementProvider
Microsoft.ConfigurationManagement.ManagementProvider.WqlQueryEngine
Församling
microsoft.configurationmanagement.managementprovider
adminui.wqlqueryengine
Robust programmering
De Configuration Manager undantag som kan aktiveras är SmsConnectionException och SmsQueryException. Dessa kan fångas tillsammans med SmsException.
Se även
Översikt över objektConfiguration Manager Lazy PropertiesHow to Call a Configuration Manager Object Class Method by Using Managed CodeHow to Connect to a Configuration Manager Provider using Managed CodeHow to Create a Configuration Manager objekt med hjälp av hanterad kodSå här ändrar du ett Configuration Manager objekt med hjälp av hanterad kodSå här utför du en synkron Configuration Manager fråga med hjälp av hanterad kodSå här läser du en Configuration Manager Objekt med hjälp av hanterad kodSå här läser du Lazy-egenskaper med hjälp av hanterad kodSå här utför du en synkron Configuration Manager fråga med hjälp av hanterad kodConfiguration Manager utökat WMI-frågespråkConfiguration Manager resultatuppsättningarConfiguration Manager särskilda frågorom frågor