有没有办法从 Quarkus Kogito 的数据库中加载决策表?

问题描述

在 quarkus kogito 中,规则(决策表)是从资源文件夹中的 xls 文件中选取的。 我想将决策表存储在数据库中,然后从那里加载决策表。

@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
@Path("/credit") 
public class CreditResource {
```
    @Inject
    KieRuntimeBuilder runtimeBuilder;

    @POST
    @Produces(MediaType.TEXT_PLAIN)
    public Boolean getCredit(Person p) {
        String drl = ""; //assume that string drl holds what is returned from the database
        KieServices kieServices = KieServices.Factory.get();
        KieFileSystem kfs = kieServices.newKieFileSystem();
        kfs.write( "src/main/resources/org/acme/person-rules.xls",kieServices.getResources().newReaderResource( new StringReader(drl) ) );
        kieServices.newKieBuilder( kfs ).buildAll();
        KieSession ksession = runtimeBuilder.newKieSession();
        ksession.insert(p);
        ksession.fireAllRules();
        return p.isApproved();

    }
}

 - List item

POJO of Person with fields: amount,credit,existing loan,approved.

But this doesn't seem to work as no rules are being fired when 

解决方法

这里是 Kogito 开发人员。

目前无法从数据库中提取决策表。然而,即使我们实现了这个功能,我也不认为它会像你期望的那样工作。

我假设您想从数据库中提取决策表,因为您想在运行时加载它。然而,在 Kogito 中,DT 的预处理仍然会在构建时进行,因为它通常发生在 Kogito 的大多数功能中;这意味着,如果您对数据库应用更改,您不会立即看到这些更改,但您仍然需要重建和重新部署您的应用程序。

希望这能回答您的问题。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...