WQL(基本上是 WMI 的 SQL)不支持 TOP 或 LIMIT 关键字。 Sql Server 使用 TOP 和许多其他 RDBMS 支持 LIMIT 等。
是否有一种解决方法可以模拟 SELECT 查询的行为,就好像它具有将结果集限制为某个任意数字的 TOP/LIMIT 子句?
或者是否有其他一些特定于 WQL 的关键字,其作用类似于 TOP 或 LIMIT?
不,没有办法单独使用 WQL 来模拟 TOP。
例外:如果您足够幸运,能够查询一个 WMI 类,该类使用无间隙的升序数字实例编号作为键,那么您可以使用大于和小于比较来限制和分页结果。
有可能ManagementClass.GetInstances()不使用 WQL 查询可能会允许您在收集了足够的实例后中途取消枚举,从而避免支付一次枚举整个列表的 CPU 和 RAM 成本。
请注意,据我所知,CIMV2 WMI 提供程序本身并不处理 WQL,而是仅依赖 WMI 枚举所有实例、处理 WQL 并在将结果返回给调用者之前过滤结果。但昂贵的部分(实际上获取底层 WMI 数据)仍然完成。因此,我认为使用 WQL 与使用 GetInstances() 并自行过滤结果相比,不会获得任何效率提升(对于本地 WMI 查询而言)——如果 GetInstances() 允许您中途取消,则 GetInstances()对于长结果集可能要便宜得多。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)