Drools:在数据库中存储规则
发布时间:2020-05-23 10:06:53 所属栏目:MsSql 来源:互联网
导读:目前,我将所有规则文件存储在文件系统上(有很多版本),并在启动时将不同版本的文件加载到内存中.我想改变将我的流口水文件存储在数据库中,并且想知道Drools是否有任何解决方案或插件,这有助于这个或我应该制作自己的? 谢谢. 是的,可以做到.所有你需要的是获取
|
目前,我将所有规则文件存储在文件系统上(有很多版本),并在启动时将不同版本的文件加载到内存中.我想改变将我的流口水文件存储在数据库中,并且想知道Drools是否有任何解决方案或插件,这有助于这个或我应该制作自己的? 谢谢. 解决方法是的,可以做到.所有你需要的是获取InputStream的能力.在我的情况下,我使用我自己的JPA类RulePackage来保持规则源为byte [],但是您可以使用直接JDBC连接来访问DB模式中的BLOB / CLOB字段.重要的是保存存储规则源的类型,构建规则包时将需要它:switch(rulePackage.getRuleSourceType()) {
case DRL:
kbuilder.add( ResourceFactory.newByteArrayResource(rulePackage.getSource()),ResourceType.DRL);
break;
case EXCEL:
kbuilder.add( ResourceFactory.newByteArrayResource(rulePackage.getSource()),ResourceType.DTABLE,excelConfig);
break;
case CSV:
kbuilder.add( ResourceFactory.newByteArrayResource(rulePackage.getSource()),csvConfig);
break;
default:
throw new Exception("Rule package '" + rulePackage.getName() + "' has unknown type");
}
您可以考虑使用newInputStreamResource方法,如果更适用于您的情况: case DRL:
kbuilder.add( ResourceFactory.newInputStreamResource(new StringInputStream(myDrlAsString)),ResourceType.DRL);
break;
要么 case DRL:
kbuilder.add( ResourceFactory.newInputStreamResource(new ByteArrayInputStream(myDrlAsByteArr)),ResourceType.DRL);
break;
这样的东西 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
