语法

There are 1 entries for the tag 语法

WMI中的SQL,WQL简明教程系列4:语法

MitchellChu 2013-06-16 .NET技术 其他技术 编程语言

  WMI的WQL简明教程系列的前三篇文章[1,2,3]分别介绍WQL中的关键字,运算符和WMI中的类,由这三个东西,理论上已经能够完成WQL语句的编写了,不过也仅是理论上。就好比盖房子,理论上有水泥,钢筋和砖头是可以盖的,但实际上,并不是一定能盖出好房子的,甚至房子盖不成的也有,要盖好房子,还需要一个设计图纸,相对应的,咱们的WQL也同样,只有了一些基础的配件,有的时候并不一定能够装配出能正常运行的WQL语句。为了能够让我们能够组装出能够运行的WQL语句,就需要WQL的设计图纸——语法。   从WQL关键字篇我们能够看到,WQL并没有UPDATE,INSERT这类SQL中的语句,因此我们能够想象的到,WMI的WQL最主要的功能就是为了查询系统数据,因此我们学习WQL语法的时候,首先只要能够了解到查询数据的语法,基本上就能够应付大部分情况了,怎么样,还是相当的简单吧?那让我们开始吧,先看看下面的WQL: SELECT * FROM Device WHERE __CLASS = "Modem" OR __CLASS = "Keyboard"   从上面的语句中我们能够看到WQL的基本语法结构,其和SQL语法类似,但WQL中多处了ASSOCIATORS OF和 REFERENCES OF两个查询结构,具体的WQL查询分为Schema,Data和Event查询,他们的区别: 数据查询:用于获取类实例,它返回特定类的所有实例,包括各自的请求属性集 Schema查询:获取类定义,使用的基本语法的形式与其他类型的查询一样 事件查询:用于过滤出一个特定事件通知的属性。事件表征被管理环境的变更。 每个查询允许添加一些附加的操作符,如: WITHIN:指定轮询 GROUP:分组相同的事件 HAVING:过滤WITHIN和GROUP子句收集事件的通知。一般与NumberofEvents属性(收集事件数量)一起。这样可以侦测何时特定事件的数量超过了时间间隔中设置的极限。 下面是Schema和Data查询的语法结构: ; ----------------------------------- ; http://blog.useasp.net/ ; MitchellChu's Blog ; WQL tutorial ; WQL schema and data 查询的语法结构 ; ----------------------------------- DATA-WQL = ("SELECT" <PROPERTY-LIST> "FROM" <CLASS-NAME> <OPTIONAL-SEL-WHERE>)/ ("SELECT" ASTERISK "FROM" <CLASS-NAME> <OPTIONAL-SEL-WHERE>)/ ("SELECT" ASTERISK "FROM META_CLASS" <OPTIONAL-META-WHERE>)/ ("ASSOCIATORS OF {" <OBJECT-REL-PATH> "}" <OPTIONAL-ASSOC-WHERE>)/ ("REFERENCES OF {" <OBJECT-REL-PATH> "}" <OPTIONAL-REF-WHERE>) ;======================================== ; PROPERTY-LIST:属性列表 ; 属性列表有属性名组成,多个属性名使用逗号分隔 ; 如果奥全部选择,可以直接使用*(星号)代替 ;======================================== PROPERTY-LIST = <PROPERTY-NAME> <PROPERTY-LIST2> PROPERTY-LIST2 = [COMMA...

关于博主

  一枚成分复杂的网络IT分子,常年游弋于电子商务,属于互联网行业分类中的杂牌军。当前正在待业中...