下面是excel规则表的图像(基本语法)。

现在,在第4条规则中,我的存储号是*,现在我试图添加一个规则,如果没有从第1行执行到第3行,那么无论哪个存储区,只有我的第4条规则都应该执行。
现在,我尝试添加议程组,以便将第1行到第3行的优先级分配给。但是,如何检查是否执行none(1到3行),那么我的第4条规则应该运行。
但是在drools中,不管执行1到3行,这个事实都是试图检查第4条规则。
如何确保只在其他行未执行时才运行第4行。
发布于 2021-07-19 13:33:33
发布于 2021-07-19 18:07:47
虽然标志/控制事实流是一种可能性(如Luca在另一个答案中所描述的),另一种可能是先让您的“默认”规则走,然后由后续规则覆盖结果。
因此,如果您的规则将“有效”指示符设置为true,则应该先将默认规则设置为false,然后其他规则可以根据需要覆盖它。
从功能上讲,工作流相当于这个Java代码:
boolean valid = false; // "default" rule sets this in all cases
if ( condition1 ) { // "rule 1" sets to true
valid = true;
}
if ( condition2 ) { // "rule 2" sets to true
valid = true;
}
// etc.
// if no "rules" hit, default value from "default rule" remains“控制事实”流等效于以下代码:
boolean valid;
boolean hasRuleHit = false;
if (condition1) {
valid = true;
hasRuleHit = true;
}
if (condition2) {
valid = true;
hasRuleHit = true;
}
// etc
if (!hasRuleHit) {
// "default" rule only triggers if the "flag" doesn't indicate that any other rule has hit
valid = false;
}从结构上讲,两者的区别在于,“默认优先”工作流要求您在规则中强制执行顺序,无论是通过显着性,还是故意不使用显着性并首先列出该默认规则;“控制事实”流将增加内存占用,因为您要将数据插入工作内存中。
https://stackoverflow.com/questions/68431020
复制相似问题