如何解决从 Excel 获取 Drools 规则引擎中的默认规则
下面是excel规则表的图片(基本语法)。
现在在我的商店编号为 * 的第 4 条规则中,我现在尝试添加一条规则,如果没有从第 1 行到第 3 行执行任何规则,那么无论任何商店,都应执行我的第 4 条规则。
现在我尝试添加议程组,以便优先考虑第 1 行到第 3 行。但是如何检查是否没有执行(1 到 3 行)然后我的第 4 条规则应该运行。
但在流口水中,无论执行 1 到 3 行,事实都试图检查第 4 条规则。
如何确保仅在其他行未执行时才运行第 4 行。
解决方法
您可以使用控制事实,规则#1 到#3 将在结果中的工作内存中插入一个对象,规则#4 将检查该对象不存在。
这是 Drools 中的常见模式,我认为它可能更适合您的情况,而不是使用规则流组。
我已经在 this video 中讨论过控制事实,并且在 Drools 的 codebase 中也有一个例子
,虽然标志/控制事实流是一种可能性(如 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;
}
从结构上讲,两者之间的区别在于“默认优先”工作流程要求您通过显着性或故意从不使用显着性并首先列出该默认规则来强制执行规则中的顺序;并且“控制事实”流会增加您的内存占用,因为您将数据插入到工作内存中。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。