Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
W Configuration Manager uruchamiasz SMS_Query zapytanie oparte na wystąpieniu zapytania, a następnie uruchamiając zapytanie WQL we właściwości obiektu SMS_QueryExpression.
Po utworzeniu zapytania WQL możesz uruchomić zapytanie synchronicznie lub asynchronicznie. Poniższy przykład jest synchroniczny. Aby uzyskać informacje na temat asynchronicznego uruchamiania zapytania, zobacz How to Perform an Asynchronous Configuration Manager Query by Using Managed Code and How to Perform an Asynchronous Configuration Manager Query by Using WMI (Jak wykonać asynchroniczne zapytanie Configuration Manager przy użyciu usługi WMI). W tych przykładach zmień ciąg na select * from collectionExpression wartość właściwości.
Aby uruchomić zapytanie
Skonfiguruj połączenie z dostawcą programu SMS. Aby uzyskać więcej informacji, zobacz Podstawy dostawcy programu SMS.
SMS_QueryPobierz obiekt dla zapytania, które chcesz uruchomić.Uruchom zapytanie zidentyfikowane przez właściwość obiektu
SMS_QueryExpression.
Przykład
Poniższa przykładowa metoda synchronicznie uruchamia zapytanie zidentyfikowane przez queryId parametr .
Aby uzyskać informacje na temat wywoływania przykładowego kodu, zobacz Wywoływanie fragmentów kodu Configuration Manager.
Sub RunQuery(connection, queryId)
Dim query
Dim queryResults
Dim queryResult
' Get query.
Set query=connection.Get("SMS_Query.QueryID='" & queryId & "'" )
If err.number<>0 Then
WScript.echo "Couldn't get Queries"
Exit Sub
End If
' Run query.
WScript.echo query.Name
WScript.echo "----------------------------------"
Set queryResults=connection.ExecQuery(query.Expression)
For Each queryResult In queryResults
wscript.echo " " & queryResult.Name
Next
If queryResults.Count=0 Then
WScript.echo " no query results"
End If
End Sub
public void RunQuery(WqlConnectionManager connection, string queryId)
{
try
{
// Get the query.
IResultObject query = connection.GetInstance(@"SMS_Query.QueryID='" + queryId + "'");
Console.WriteLine(query["Name"].StringValue);
Console.WriteLine("----------------------------------");
// Get the query results.
IResultObject queryResults = connection.QueryProcessor.ExecuteQuery(query["Expression"].StringValue);
bool resultsFound = false;
foreach (IResultObject queryResult in queryResults)
{
resultsFound = true;
Console.WriteLine(queryResult["Name"].StringValue);
}
if (resultsFound == false)
{
Console.WriteLine(" No query results");
}
}
catch (SmsException ex)
{
Console.WriteLine("Failed to run query: " + ex.Message);
throw;
}
}
Przykładowa metoda ma następujące parametry:
| Parametr | Wpisać | Opis |
|---|---|---|
connection |
-Zarządzane: WqlConnectionManager- VBScript: SWbemServices |
Prawidłowe połączenie z dostawcą programu SMS. |
queryID |
-Zarządzane: String- VBScript: String |
Identyfikator zapytania. Aby uzyskać więcej informacji, zobacz właściwość SMS_Query klasy QueryID . |
Kompilowanie kodu
Przykład języka C# ma następujące wymagania dotyczące kompilacji:
Przestrzenie nazw
System
System.Collections.Generic
System.Text
Microsoft.ConfigurationManagement.ManagementProvider
Microsoft.ConfigurationManagement.ManagementProvider.WqlQueryEngine
Montaż
microsoft.configurationmanagement.managementprovider
adminui.wqlqueryengine
Niezawodne programowanie
Aby uzyskać więcej informacji na temat obsługi błędów, zobacz Informacje o błędach Configuration Manager.
zabezpieczenia .NET Framework
Aby uzyskać więcej informacji na temat zabezpieczania aplikacji Configuration Manager, zobacz Configuration Manager administracja oparta na rolach.
Zobacz też
Informacje o Configuration Manager zapytaniachJak utworzyć zapytanie Configuration ManagerJak wykonać asynchroniczne zapytanie Configuration Manager przy użyciu kodu zarządzanegoJak wykonać asynchroniczne Configuration Manager zapytanie przy użyciu usługi WMI