Hashmap с объектом в качестве ключа в правиле Drools

Для работы с данными, скомпилированными в моей локальной базе данных, я создал HashMap с объектом в качестве ключа и String в качестве значения, содержащего данные, которые мне нужны.

Когда я передаю этот HashMap и ключ в сеанс Drools, я обнаруживаю, что не могу получить требуемое значение с помощью этого ключа.

Вот ошибка, которую я получаю:

org.drools.runtime.rule.ConsequenceException: rule: Education
            at org.drools.runtime.rule.impl.DefaultConsequenceExceptionHandler.handleException(DefaultConsequenceExceptionHandler.java:39)
            at org.drools.common.DefaultAgenda.fireActivation(DefaultAgenda.java:916)
            at org.drools.common.DefaultAgenda.fireNextItem(DefaultAgenda.java:845)
            at org.drools.common.DefaultAgenda.fireAllRules(DefaultAgenda.java:1056)
            at org.drools.common.AbstractWorkingMemory.fireAllRules(AbstractWorkingMemory.java:733)
            at org.drools.common.AbstractWorkingMemory.fireAllRules(AbstractWorkingMemory.java:699)
            at org.drools.impl.StatefulKnowledgeSessionImpl.fireAllRules(StatefulKnowledgeSessionImpl.java:218)
            at com.example.jeanineharb.reasoning.TriggerReceiver.onReceive(TriggerReceiver.java:117)
            at android.app.ActivityThread.handleReceiver(ActivityThread.java:2609)
            at android.app.ActivityThread.access$1700(ActivityThread.java:151)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1380)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5254)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
     Caused by: [Error: unable to resolve method: java.util.HashMap.$k() [arglength=0]]
    [Near : {... this[$k] ....}]
    ^
    [Line: 1, Column: 6]
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.getMethod(ReflectiveAccessorOptimizer.java:1094)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.getMethod(ReflectiveAccessorOptimizer.java:1003)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.getBeanProperty(ReflectiveAccessorOptimizer.java:693)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.compileGetChain(ReflectiveAccessorOptimizer.java:360)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.optimizeAccessor(ReflectiveAccessorOptimizer.java:163)
            at org.mvel2.optimizers.dynamic.DynamicOptimizer.optimizeAccessor(DynamicOptimizer.java:81)
            at org.mvel2.ast.ASTNode.optimize(ASTNode.java:159)
            at org.mvel2.ast.ASTNode.getReducedValueAccelerated(ASTNode.java:115)
            at org.mvel2.compiler.ExecutableAccessor.getValue(ExecutableAccessor.java:38)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.getCollectionProperty(ReflectiveAccessorOptimizer.java:758)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.compileGetChain(ReflectiveAccessorOptimizer.java:366)
            at org.mvel2.optimizers.impl.refl.ReflectiveAccessorOptimizer.optimizeAccessor(ReflectiveAccessorOptimizer.java:163)
            at org.mvel2.optimizers.dynamic.DynamicOptimizer.optimizeAccessor(DynamicOptimizer.java:81)
            at org.mvel2.ast.ASTNode.optimize(ASTNode.java:159)
            at org.mvel2.ast.ASTNode.getReducedValueAccelerated(ASTNode.java:115)
            at org.mvel2.MVELRuntime.execute(MVELRuntime.java:85)
            at org.mvel2.compiler.CompiledExpression.getDirectValue(CompiledExpression.java:123)
            at org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:119)
            at org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:113)
            at org.mvel2.MVEL.executeExpression(MVEL.java:954)
            at org.drools.base.extractors.MVELClassFieldReader.getValue(MVELClassFieldReader.java:153)
            at org.drools.rule.Declaration.getValue(Declaration.java:219)
            at org.drools.base.mvel.MVELCompilationUnit.updateFactory(MVELCompilationUnit.java:358)
            at org.drools.base.mvel.MVELCompilationUnit.getFactory(MVELCompilationUnit.java:282)
            at org.drools.base.mvel.MVELConsequence.evaluate(MVELConsequence.java:79)
            at org.drools.common.DefaultAgenda.fireActivation(DefaultAgenda.java:906)
            ... 16 more

Вот проблемное правило:

rule "Education"
    when
        $s : Story( getQuestionContent().equals("") )
        $k : Key( )
        $msgMap : HashMap( $m : this[$k] != null )
    then
        modify ( $s ) {
           setQuestionContent( $m )
        };
end

Кто-нибудь знает, почему я получаю эту ошибку?

ETA: я использую Drools v5.2.0

1 ответ

Похоже, это немного выходит за рамки синтаксиса выражений LHS (который нигде точно не определен). Использовать этот:

rule "Education"
when
    $s : Story( questionContent == "" )
    $k : Key()
    $msgMap : HashMap( this[$k] != null )
then
    modify ( $s ) {
       setQuestionContent( $msgMap.get( $k ) )
    };
end

Обратите внимание, что вы можете использовать == для строковых значений.

Другие вопросы по тегам