问题描述
在 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 的大多数功能中;这意味着,如果您对数据库应用更改,您不会立即看到这些更改,但您仍然需要重建和重新部署您的应用程序。
希望这能回答您的问题。