Drools规则引擎-.drl文件的规则语法二
转载
drl关键字
关键字 | 含义 |
---|
salience | 定义规则优先级的整数,数值越大,优先级越高 |
enabled | 规则启用开关 |
date-effective | 包含日期和时间定义的字符串。仅当当前日期和时间在date-effective属性之后时,才能激活该规则。 |
date-expires | 如果当前日期和时间在date-expires属性之后,则无法激活该规则。 |
no-loop | 选择该选项后,如果规则的结果重新触发了先前满足的条件,则无法重新激活(循环)规则。如果未选择条件,则在这些情况下可以循环规则。 |
agenda-group | 标识要向其分配规则的议程组 |
activation-group | 激活组,在激活组中,只能激活一个规则。触发的第一个规则将取消激活组中所有规则的所有未决激活。 |
duration | 定义了如果仍满足规则条件,则可以激活规则的持续时间(以毫秒为单位)。 |
timer | cron定时表达式 |
calendar | 时钟 |
auto-focus | 仅适用于议程组中的规则。选择该选项后,下次激活该规则时,将自动将焦点分配给分配了该规则的议程组。 |
lock-on-active | no-loop属性的更强版 |
ruleflow-group | 标识规则流组的字符串 |
dialect | 用于标识规则中的代码表达式JAVA或MVEL将其用作语言 |
约束
关键字 | 含义 |
---|
!. | 使用此运算符可以以空安全的方式取消引用属性。!.运算符左侧的值不能为null(解释为!= null) |
[] | 按List索引访问值或Map按键访问值 |
<,<=,>,>= | 在具有自然顺序的属性上使用这些运算符 |
==, != | 在约束中使用这些运算符作为equals()和!equals()方法 |
&&, |
|
matches,not matches | 使用这些运算符可以指示字段与指定的Java正则表达式匹配或不匹配 |
contains,not contains | 使用这些运算符可以验证Array或字段是否包含或不包含指定值 |
memberOf,not memberOf | 使用这些运算符可以验证字段是否为定义为变量Array的成员 |
soundslike | 使用英语发音来验证单词是否具有与给定值几乎相同的声音(类似于该matches运算符) |
in,notin | 使用这些运算符可以指定一个以上的可能值来匹配约束(复合值限制) |
accumulate 函数
- average
- min
- max
- count
- sum
- collectList 获取列表
- collectSet 获取集合
同JDK1.8中的lambda表达式的函数
本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。