【java规则引擎】《Drools7.0.0.Final规则引擎教程》第4章 4.2 activation-group& dialect& date-effective
转载至:https://blog.csdn.net/wo541075754/article/details/75511887
activation-group
该属性将若干个规则划分成一个组,统一命名。在执行的时候,具有相同activation-group 属性的规则中只要有一个被执行,其它的规则都不再执行。可以用类似salience之类属性来实现规则的执行优先级。该属性以前也被称为异或(Xor)组,但技术上并不是这样实现的,当提到此概念,知道是该属性即可。
实例代码:
package com.rules rule "test-activation-group1" activation-group "foo" when then System.out.println("test-activation-group1 被触发"); end rule "test-activation-group2" activation-group "foo" salience 1 when then System.out.println("test-activation-group2 被触发"); end
执行规则之后,打印结果
test-activation-group2 被触发
以上实例证明,同一activation-group优先级高的被执行,其他规则不会再被执行。
dialect
该属性用来定义规则(LHS、RHS)当中要使用的语言类型,可选值为“java”或“mvel”。默认情况下使用java语言。当在包级别指定方言时,这个属性可以在具体的规则中覆盖掉包级别的指定。
dialect "mvel"
date-effective
该属性是用来控制规则只有在到达指定时间后才会触发。在规则运行时,引擎会拿当前操作系统的时间与date-effective设置的时间值进行比对,只有当系统时间大于等于date-effective设置的时间值时,规则才会触发执行,否则执行将不执行。在没有设置该属性的情况下,规则随时可以触发。
date-effective的值为一个日期型的字符串,默认情况下,date-effective可接受的日期格式为“dd-MMM-yyyy”。例如2017 年7 月20 日,在设置为date-effective值时,如果操作系统为英文的,那么应该写成“20-Jul-2017”;如果是中文操作系统则为“20-七月-2017”。
目前在win10操作系统下验证,中文和英文格式均支持。而且在上面日期格式后面添加空格,添加其他字符并不影响前面日期的效果。
示例代码:
package com.rules rule "test-date" // date-effective "20-七月-2017 aa" // date-effective "20-七月-2017" // date-effective "20-Jul-2017aaa" date-effective "20-Jul-2017" when then System.out.println("规则被执行"); end
值得注意的是以上注释掉的格式均能成功命中规则与后面的字符无关,因为默认时间格式只取字符串的指定位数进行格式化。
晋级用法:上面已经提到了,其实针对日期之后的时间是无效的。那么如果需要精确到时分秒改如何使用呢?可以通过设置drools的日期格式化来完成任意格式的时间设定,而不是使用默认的格式。在调用代码之前设置日期格式化格式:
System.setProperty("drools.dateformat", "yyyy-MM-dd HH:mm");
在规则文件中就可以按照上面设定的格式来传入日期:
date-effective "2017-07-20 16:31"
4.2.10 date-expires
此属性与date-effective的作用相反,用来设置规则的过期时间。时间格式可完全参考date-effective的时间格式。引擎在执行规则时会检查属性是否设置,如果设置则比较当前系统时间与设置时间,如果设置时间大于系统时间,则执行规则,否则不执行。实例代码同样参考date-effective。
4.2.11 duration
已废弃。设置该属性,规则将指定的时间之后在另外一个线程里触发。属性值为一个长整型,单位是毫秒。如果属性值设置为0,则标示立即执行,与未设置相同。
4.2.12 enabled
设置规则是否可用。true:表示该规则可用;false:表示该规则不可用。