Drools决策表的使用

Drools 决策表的使用

决策表简介

引用官方的话

决策表是一个“精确而紧凑的”表示条件逻辑的方式,非常适合商业级别的规则。 目前决策表支持xls格式和csv格式。决策表与现有的drools drl文件使用可以无缝替换。

什么时候使用决策表

  • 规则能够被表达为模板+数据的格式,考虑使用决策表
  • 很少量的规则不建议使用决策表
  • 不是遵循一组规则模板的规则也不建议使用决策表

决策表格式

RuleSet 和 drl 文件中的 package 是一样

  • RuleSet 和 drl 文件中的 package 是一样
  • Sequential 与 drl 文件中的属性优先级是一样的,只是这边为 true
  • Functions 与 drl 文件中的 function 是一样的
  • RuleTable 表示 rule name,必添
  • CONDITION ACTION 表示 rule 中的 LHS RHS 部分 至少要有一个
  • 从CONDITION 下面两行则表示 LHS 部分 第三行则为注释行,不计为规则部分,从第 四行开始,每一行表示一条规则。
  • $param 表示占位符会替换下面每一行的值,生成一条规则。

决策表的语法

决策表编译

首先需要引入maven的pom依赖:

<dependency>
    <groupId>org.drools</groupId>
    <artifactId>drools-decisiontables</artifactId>
    <version>7.0.0.Final</version>
</dependency>

可以通过以下两个方式来对决策表进行解析生成drl文件:

@Test
    public void checkDrl() throws FileNotFoundException {
        File file = new File("E:\\GitHub\\respo\\drools-lesson\\src\\main\\resources\\decision.xls");
        InputStream is = new FileInputStream(file);
        SpreadsheetCompiler compiler = new SpreadsheetCompiler();
        String drl = compiler.compile(is, InputType.XLS);
        System.out.println(drl);
    }

    @Test
    public void checkDrl2() throws FileNotFoundException {
        SpreadsheetCompiler compiler = new SpreadsheetCompiler();
        String drl = compiler.compile(ResourceFactory.newClassPathResource("com/decision/decision.xls"), InputType.XLS);
        System.out.println(drl);
    }

可以通过查看生成的drl内容确定决策表的语法及业务是预期的。

与drl文件方式无缝结合

像配置drl文件格式的规则一样,我们要执行一个xls决策表操作非常简单,只用把drl文件替换为对应的xls文件即可。

具体配置如下: kmodule.xml中配置xls所在的resource目录对应的session:

<kbase name="decision-kbase" packages="com.decision">
    <ksession name="decision-rules"/>
</kbase>

同时将决策表的xls文件放置在com.decision包中,为了减少不必要的麻烦,决策表中定义的RuleSet值也应该是com.decision。

同样的,在代码中只需像正常调用代码一样获取KieSession进行后续业务处理即可:

@Test
    public void testDecision(){

        KieSession kieSession = this.getKieSessionBySessionName("decision-rules");

        kieSession.fireAllRules();
        kieSession.dispose();
    }

打印的结果与drl文件无二。

更多详情

同时也可查看github上的代码:https://github.com/secbr/drools

如果想获得更多相关技术交流可加入QQ技术交流群:593177274

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏后端之路

SpringBoot 打包之可运行jar

背景 一个可运行的工具始终比XXX配置更加方便 每次一堆tomcat版本指定,对应jar替换 各种打包 替换properties 参考 maven profil...

30710
来自专栏大魏分享(微信公众号:david-share)

咋地,容器中真能部署有状态的应用?

在K8S中,Deployment或者ReplicaSet的控制器是面向无状态应用的。举个简单的例子,同一个dc,在不同时刻部署的pod,它的IP可能是不同的,获...

734
来自专栏小狼的世界

Kubernetes基础:Pod的详细介绍

Pod是Kubernetes中能够创建和部署的最小单元,是Kubernetes集群中的一个应用实例,总是部署在同一个节点Node上。Pod中包含了一个或多个容器...

674
来自专栏Kubernetes

kubelet最佳配置

author: garnett.wang@gmail.com kubernetes version: 1.6.2 Kubelet Configurations ...

4497
来自专栏轻量级微服务

Kubernetes Service & LB & Networking :Services

使用标签选择器创建服务,Service 直接关联 Pod,示例:部署 Mysql (细节见文末附录1),再创建服务:

964
来自专栏区块链

在Office 文档的属性中隐藏攻击载荷

Microsoft Office中的文档属性通常包含与文档和各种其他元数据详细信息相关的信息。但是,此位置可用于存储并执行SMB或HTTP服务器上托管的有效载荷...

18310
来自专栏性能与架构

认识一下 Kubernetes

2143
来自专栏琯琯博客

awesome-java-cn

Java 资源列表,内容包括:构建工具、数据库、框架、模板、安全、代码分析、日志、第三方库、书籍、Java 站点等等。 古董级工具 这些工具伴随着Java一起出...

3468
来自专栏Java技术

Kafka设计解析(二)- Kafka High Availability (上)

http://www.jasongj.com/2015/04/24/KafkaColumn2/

963
来自专栏C#

最好的.NET开源免费ZIP库DotNetZip(.NET组件介绍之三)

   在项目开发中,除了对数据的展示更多的就是对文件的相关操作,例如文件的创建和删除,以及文件的压缩和解压。文件压缩的好处有很多,主要就是在文件传输的方面,文件...

2517

扫码关注云+社区