Запрос не работает на C #, но работает на PowerShell - PullRequest
1 голос
/ 06 июня 2011

Кто-нибудь знает, почему мой запрос "select Name, ProcessID, Caption from Win32_Process where ProcessId='" + processIds[index] + "'" возвращает

 Column 'Name' does not belong to table Win32_Process

в моей программе C #.

В powershell, когда я выполняю

Get-WmiObject -query "select Name, ProcessID, Caption from win32_process"

Это работает!1010 *

   String queryString = "select Name, ProcessID, Caption from Win32_Process where ProcessId='" + processIds[index] + "'";
                SelectQuery query = new SelectQuery(queryString);

                ConnectionOptions options = new ConnectionOptions();
                options.Authentication = System.Management.AuthenticationLevel.PacketPrivacy;


                ManagementScope scope = new System.Management.ManagementScope("\\root\\cimv2");
                ManagementObjectSearcher searcher = new ManagementObjectSearcher(scope, query);
                try
                {
                    ManagementObjectCollection processes = searcher.Get();
                    DataTable result = new DataTable();
                    foreach (ManagementObject mo in processes)
                    {
                        DataRow row = result.NewRow();
                        if (mo["Name"] != null)
                            row["Name"] = mo["Name"].ToString();
                        row["ProcessId"] = Convert.ToInt32(mo["ProcessId"]);
                        if (mo["Caption"] != null)
                            row["Caption"] = mo["Caption"].ToString();
                        result.Rows.Add(row);
                    }

Спасибо за помощь

1 Ответ

2 голосов
/ 06 июня 2011

Этот код:

const string queryString = "SELECT Name, ProcessID, Caption FROM Win32_Process";

var scope = new ManagementScope(@"\root\cimv2");
var query = new ObjectQuery(queryString);
var searcher = new ManagementObjectSearcher(scope, query);
var objectCollection = searcher.Get();

foreach (var o in objectCollection)
{
    Console.WriteLine("{0} {1} {2}", o["Name"], o["ProcessID"], o["Caption"]);
}

... у меня отлично работает. Как именно ваш код не работает?

(Кстати, вы ничего не делаете с options).

Обновление:

На самом деле это жалуется, потому что вы не настроили столбцы в своем DataTable. Я думаю, что вы слишком много сократили свой пример. Ваш DataTable называется "Win32_Process", да? Если я назову мой "Альберт":

var table = new DataTable("Albert");

Я получаю Column 'Name' does not belong to table Albert.

Вам нужно сделать что-то вроде следующего:

var table = new DataTable("Albert");
table.Columns.Add("Name");
table.Columns.Add("ProcessID", typeof(int));
table.Columns.Add("Caption");
...