Drools:在数据库中存储规则

前端之家收集整理的这篇文章主要介绍了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;

这样的东西

猜你在找的MsSQL相关文章