0

在 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 
4

1 回答 1

2

Kogito 开发人员在这里。

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

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

希望这回答了你的问题。

于 2021-01-07T09:19:17.477 回答