我正在通过DRT(规则模板)读取Excel表,然后通过Java类中的静态方法将其转换为类的对象。并将其插入到工作内存中。这样,工作内存就会被 Excel 表格中的所有事实填满。
现在,我通过 session 在 INSERT() 中通过 Java 类发送事实。 我需要匹配两个相似的对象并从工作内存中返回匹配的对象。 举例来说:
从 Excel 中读取并插入到工作内存中。
Person(name == "Kumar", Age == 60, status == true);
现在在 Java 类中,通过 session 我插入以下对象:
Person(name == "Kumar", Age == 60 );
然后我需要通过比较两个对象来设置Status = true
。
我需要编写比较两个对象的规则。
请建议一些方法。
谢谢 绍拉夫
最佳答案
如果我们必须假设可能存在三个或更多“相似”事实,那么最好这样做:
rule "find same name and age"
when
$p1: Person( $name: name, $age: age, status == false )
$p2: Person( name == name, age == $age, status == false, this != $p1 )
accumulate( $p: Person( name == name, age == $age, status == false );
$list: collectList( $p ) )
then
for( int i = 0; i < $list.size(); i++ ){
Person p = (Person)$list.get(i);
update( p ){ setStatus( true ) }
}
end
关于java - 流口水时比较工作内存中的对象(事实),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25845051/