1 回答
TA贡献1780条经验 获得超1个赞
您使用内部 API 来构建对用户来说并不友好的规则。
即使我们回答了这个问题,你也会发现很多这样的问题。而且内部结构最终肯定会改变,所以我建议你不要使用它。
相反,开始使用可执行模型以编程方式构建规则,这是一个完全根据您的需要创建的 Java DSL。这样你就不必担心描述符的内部结构。
看一下org.drools.modelcompiler.PatternDSLTest或org.drools.model.FlowDSLTest,您可以找到一些与您正在做的事情非常相似的示例,例如
public void testOr() {
Result result = new Result();
Variable<Person> personV = declarationOf( Person.class );
Variable<Person> markV = declarationOf( Person.class );
Variable<String> nameV = declarationOf( String.class );
Rule rule = rule( "or" )
.build(
or(
pattern( personV ).expr("exprA", p -> p.getName().equals("Mark")),
and(
pattern( markV ).expr("exprA", p -> p.getName().equals("Mark")),
pattern( personV ).expr("exprB", markV, (p1, p2) -> p1.getAge() > p2.getAge())
)
),
pattern( nameV ).expr("exprC", personV, (s, p) -> s.equals( p.getName() )),
on(nameV).execute( result::setValue )
);
Model model = new ModelImpl().addRule( rule );
KieBase kieBase = KieBaseBuilder.createKieBaseFromModel( model );
KieSession ksession = kieBase.newKieSession();
ksession.insert( "Mario" );
ksession.insert(new Person("Mark", 37));
ksession.insert(new Person("Edson", 35));
ksession.insert(new Person("Mario", 40));
ksession.fireAllRules();
assertEquals("Mario", result.getValue());
}
希望这可以帮助
添加回答
举报