过滤器中的WQL不起作用

时间:2015-02-13 14:58:38

标签: powershell wql

我正在尝试做类似的事情:

Get-WmiObject Win32_NetworkAdapterConfiguration `
    -Filter "DefaultIPGateway!=NULL"

但我有一个错误:

  

Get-WmiObject:查询无效   在行:1 char:14   + Get-WmiObject<<<< Win32_NetworkAdapterConfiguration -Filter“DefaultIPGateway!= NULL”       + CategoryInfo:InvalidOperation:(:) [Get-WmiObject],ManagementException       + FullyQualifiedErrorId:GetWMIManagementException,Microsoft.PowerShell.Commands.GetWmiObjectCommand

这很奇怪,因为当我尝试获取DefaultIPGateway值的类型时。这是现有值的System.Array:

PS> $result[0].DefaultIPGateway.Gettype()

IsPublic IsSerial Name                                     BaseType
-------- -------- ----                                     --------
True     True     String[]                                 System.Array

对于不存在的值为NULL:

PS> $result[1].DefaultIPGateway.GetType()
You cannot call a method on a null-valued expression.
At line:1 char:36
+ $result[1].DefaultIPGateway.GetType <<<< ()
    + CategoryInfo          : InvalidOperation: (GetType:String) [], RuntimeException
    + FullyQualifiedErrorId : InvokeMethodOnNull

有人可以帮助我理解为什么我的WQL不起作用以及我该怎么做才能实现它?

2 个答案:

答案 0 :(得分:2)

我不确定如何使过滤器查询工作,因为我不知道如何访问数组元素来检查它们,但有一个解决方法:

Get-WmiObject Win32_NetworkAdapterConfiguration | Where-Object { $_.DefaultIPGateway -ne $null }

这样,powershell将负责过滤从查询返回的对象,而不是WMI在检索期间执行此操作。

答案 1 :(得分:1)

WQL查询不支持数组属性。

  

注意WQL不支持对数组数据类型的查询。

来源:Querying with WQL @ MSDN

解决方案是使用PowerShell的Where-Object cmdlet过滤掉具有空值的对象。

Get-WmiObject -Class Win32_NetworkAdapterConfiguration |
Where-Object { $_.DefaultIPGateway }