1、基本的匹配规则
1.1变量
drools使用匹配的方式对Fact进行比对,
比如
- account : Account(balance > 100)
这个规则的含义就是在Fact中找到类型为Account,且balance属性值大于100的所有Account实例。
可以指定变量来描述一个类型或者一个映射一个类的属性,
比如
- $account : Account($type : type)
使用$Variable来定义一个变量,这里定义了两个变量,$account表示定义一个类型为Account的变量,而$type映射Account类型中的type属性。定义变量是为了在后续的规则中使用。
- $account : Account(balance >100)
- Customer(account == $account)
这个就是说要找到一些Custom类型的Fact,且其account属性必须满足前面定义的balance>100的条件。
1.2类型
drools支持各种java数据类型
String:字符串
- Customer(name == "john")
正则表达式:
- Customer(name matches "[A-Z][a-z]+")
表示Customer类型的name属性必须满足首字母为大写A-Z,且第二位以后有一个或者多个小写的a-z组成。
Date:日期类型
- Account(dateCreate > "01-Feb-2009")
日期的格式默认是"dd-mmmm-yyyy",可以更改。
Boolean:布尔类型
- Transaction(isApprove == true)
Enum:枚举类型
- Account(type == Account.Type.STUDENT)
1.3注释
单行注释://或者#
多行注释: /* */
1.4包
- package com.kingsun.drools.rules
声明该规则文件所属的包,是一种namespace组织方式,和java的包类似,物理上不需要存在相应的目录结构,它只是逻辑上的划分。
1.5导入
import可以导入在规则中使用到的类,也可以导入在规则中使用到的外部定义的functiong
- import java.util.Map;
- import com.kingsun.drools.service.LegacyBankService.extractData;
当导入方法时,这个方法必须是static的,因为利用的是jdk1.5的static import特性。
1.6全局变量global
声明一个global变量
- global ReportFactory reportFactory;
给全局变量赋值
- session.setGlobal("reportFactory", reportFactory);
或者
- List<Command> commands = new ArrayList<Command>();
- commmands.add(CommandFactory.newSetGlobal("reportFactory", reportFactory));
使用全局变量
- session.getGlobals();
1.7函数Functions
function可以在规则文件中定义,但更多的是使用外部类中定义的static方法,这样只要java中可以实现的逻辑,在规则中都可以做为function调用。
调用外部类的functiong需要注意的是方法必须是静态的,static,而且这个类可以在Help辅助类中定义。
外部类需要import,此时在function中用到的参数类型也需要import。
如: 在外部的ValidationHelper辅助类中定一个一个static方法
- public static double calculateAccount(Account account) {
- return 100 + account.balance * 1.2;
- }
在规则drl文件中可以这么使用:
- import com.kingsun.drools.domain.Account;
- import function com.kingsun.drools.util.ValidationHelper.calculateAccount;
- rule "validation account"
- when
- $account : Account(balance > 100)
- then
- Account(balance == calculateAccount($account));
- end
1.8方言dialect
在规则表达式中可以使用方言来简化表达式,使之更加具有可读性。
- package com.kingsun.drools.rules;
- dialect "mvel"
方言默认的是java,drools也支持mvel,在package的后面声明该规则文件使用的方言
mvel
mvel是一种基于java应用程序的表达式语言,它支持属性和方法的直接访问
简单属性表达式:
- ($customer.name == "john") && (balance > 100)
满足姓名为“john”,且balance必须大于100的customer
支持属性导航:
Bean属性导航
- $customer.address.postalCode = "123" 等同于 $customer.getAddress().setPostalCode("123")
访问List数据结构
- $customer.accounts[3] 等同于 $customer.getAccounts(3)
访问Map数据结构
- $customerMap["123"] 等同于$customerMap.get["123"]
内置的List、Map和数组arrays
Map:创建一个AccountMap实例-->
- ["001", new Account("001"), "002", new Account("002")]
等同于创建了一个Map,并向Map中put了两个entry。
List:创建一个List实例-->
- ["001", "002", "003"]
等同于创建了一个List,并向List中add了三个对象。
Arrays:创建一个数组-->
- {"001", "002", "003"}
等同于创建了一个Array,并初始化了三个成员。
嵌套
使用这个可以方便的访问复杂对象中包括的集合类型的对象。
- listOfPostCode = (postCode in (addresses in $customerS))
这个得到一个postCode列表,它是customers集合中的每一个custemer对象的地址属性中包含的postCode信息的汇集。
强制转换
当使用array = {1, 2, 3}时,mvel会自动将元素转换成integer类型。
返回值
保存变量的值等于最后一次赋予的值。
mvel同时还支持方法调用、控制流、赋值、动态类型等等,使用mvel的性能很好,不过要小心使用。在drools中有一些核心特性就是通过mvel来实现的。
1.9规则的条件部分
And 与
- $customer : Customer(name == "john", age > 20)
在condition中使用换行来表示与
OR 或
- $customer : Customer(name == "john" || age > 20)
Not 非
- not Account(type == Account.Type.STUDENT)
表示所有账户类型不是STUDENT的账户
exists 存在
- exists Account(type == Account.Type.STUDENT)
Eval
捕获异常,只要eval表达式中的结果为true或者false就可以
- $account : Account()
- eval(accountService.isUniqueAccountNumber($account))
返回值约束
- $customer1 : Customer()
- Customer(age == ($customer.getAge + 10))
内置eval
- $customer1 : Customer()
- Customer(eval(age == $customer1.getAge() + 10))
和上个例子一样,只是使用了内置的eval来写的。
内置eval不能使用this,比如:
- $customer1 : Customer()
- $customer2 : Customer(this != $customer1)
customer1和customer2不是同一个对象实例
使用内置的eval表达式来描述:
- $customer1 : Customer()
- $customer2 : Customer(eval($customer2 != $customer1))
注意,在内置的eval中不能使用this来指代自己。
嵌套访问
- $customer : Customer()
- Account(this == $customer.accounts[0])
得到所有customer对象中的第一个账号
如果一个嵌套访问的对象属性值更改了,我们使用modify来提示drools属性改变了。
This
this指向当前的Fact
和集合相关的运算
contains
- $account : Account()
- $customer : Customer(accounts contains $account)
- $customer : Customer(accounts not contains $account)
member of
- $customer : Customer($accounts : accounts)
- Account(this member of $accounts)
- 或
- Account(this member of $customer.accounts)
From
- $customer : Customer()
- Account() from $customer.accounts
from可以接受service的方法调用后的结果集,也可以指向一个对象或者一个集合
1.10规则的推理部分
规则引擎的作用就是在于根据预先制定的规则去和事实匹配,对符合激发条件的规则,执行规则中定义的推理,作出相应的处理。
有时候,规则和规则之间存在冲突,drools使用冲突解决策略来解决矛盾。有两种办法:一个是设置规则的优先级,优先级高的先触发。另一个是
在推理部分不推荐使用if then这样的条件判断语句,它应该是明确的行为,因为条件判断应该在LHS中就已经明确区分出来了,如果推论部分存在条件判断的话,应该增加新的规则以满足要求。这样做符合最佳实践。
当一个规则被激活,并且推理部分被执行,它可能会对Fact做一些修改或者更新,这样的修改和更新可能会激活更多的其他规则,因此,必须在推论部分明确指出这个规则对Fact作出的更新和修改,Drools能够及时对Fact进行更新,这样其他规则才能及时应用到最新的Fact数据上来。
推论部分经常使用的几个函数
modify 修改
更新session中存在的Fact
- rule "interst calculation"
- no-loop
- when
- $account : Account()
- then
- modify($account) {
- setBalance((double)($account.getBalance() * 1.2))
- };
- end
insert 插入
向session的Fact中新增一个事实
- insert(new Account())
retract 收回
从session的Fact中移除一个事实
- retract(0)
1.11规则的属性部分
规则属性出现在rule和when关键字之间,用于修改和增强标准的规则行为。
- rule "rule attribute"
- salience 100
- dialect "mvel"
- no-loop
- when
- //conditons条件部分
- then
- //consquence推论部分
- end
salience
salience是优先级的意思,它可以为负数,salience越高,表明规则的优先级越高,越先被激发。
默认值是0。
no-loop
表明对于每一个Fact实例,该规则只能被激活一次。
dialect
指定方言。
- dialect "mvel"
相关推荐
Drools 语法是一种基于规则的引擎,用于 business logic 的自动化处理。Drools 语法教程旨在为初学者提供详细的语法指南,帮助他们快速掌握 Drools 的使用。 在 Drools 中,规则的编译与运行需要通过提供的各种 ...
【Drools规则引擎从入门到精通】 Drools是一个强大的业务规则管理系统,它提供了业务规则引擎、Web创作工具(Drools Workbench)以及决策模型符号(DMN)的支持。作为一个开源项目,Drools使用Java编写,遵循Apache...
3. **Drools规则语法**: - `rule "规则名"` 定义一个规则,规则名用于标识规则。 - `when` 开始定义规则的条件,可以使用Drools的DSL(Domain Specific Language)或者MVEL表达式。 - `then` 规则的行动部分,当...
接下来,我们将深入到Drools的规则语法: 1. 规则文件: 规则通常保存在.drl文件中,遵循Drools特定的语法。一个规则文件可以包含多个规则,每个规则都有自己的名称。 2. 规则语言: Drools 使用基于DRL(Drools...
Drools规则通常使用Drools Rule Language (DRL)编写,这是一种简洁而强大的语言,允许开发者以自然语言风格定义业务规则。DRL支持条件表达式、函数调用等多种语法结构,并且能够与Java无缝集成,提供强大的扩展性。 ...
DROOLS规则语言(DRL)是一种基于Java的领域特定语言(DSL),用于编写业务规则。本文档将详细介绍DROOLS的基本语法结构及其各个组成部分。 #### 二、DROOLS基本语法结构 DROOLS的基本语法结构由以下几个关键部分...
2、规则语法 (1)、演示drl文件格式 package droolRule ; import org.slf4j.Logger import org.slf4j.LoggerFactory ; dialect "java" rule "paramcheck1" when then final Logger LOGGER = LoggerFactory....
然后,创建一个Drools规则仓库,将规则以DRL(Drools Rule Language)文件的形式存储在MySQL的BLOB字段中。DRL是一种文本格式,用于编写Drools规则。当需要更新规则时,可以直接在数据库中编辑DRL内容,无需重新部署...
Drools基础语法 规则属性 Drools高级语法 Spring整合Drools Spring Boot整合Drools WorkBench Drools实战 个人所得税计算器 信用卡申请 保险产品准入规则 规则引擎,全称为业务规则管理系统,英文名为BRMS(即...
3. **规则语法**:掌握Drools的DRL(Drools Rule Language)语言,学习如何编写规则,包括条件语句(LHS,左侧)和动作语句(RHS,右侧)。 4. **规则的加载与执行**:学习如何使用KieSession加载规则,并通过...
- **定义**:Drools规则语言(DRL)是由Drools开源项目提供的一种专用语言,用于定义业务规则。 - **文件格式**:DRL规则被定义在`.drl`文件中。 - **组成**:一个DRL文件可以包含一个或多个规则,这些规则至少定义...
2. **Drools规则引擎**:Drools(JBossRules)是一个易于访问企业策略、易于调整和管理的开源业务规则引擎。它符合业界标准,并以速度快、效率高著称。业务分析师或审核人员可以轻松查看和验证编码规则是否执行了所...
Drools规则引擎是一种嵌套在应用程序中的组件, 是用Java语言编写的开放源码规则引擎,使用Rete算法对所编写的规则求值。 它实现了将业务规则从程序代码忠分离出来,规则引擎使用特定的语法编写业务规则,规则引擎...
总结来说,Drools规则引擎是一种强大的业务逻辑管理系统,它通过为业务规则提供灵活定义和运行时执行的能力,增强了业务逻辑的可维护性和可扩展性。熟练掌握Drools的开发和使用,需要对规则引擎的基本原理、Drools的...
通过使用Drools规则引擎,企业能够以一种更加灵活、高效的方式来管理复杂的业务逻辑。这种方式不仅简化了代码结构,提高了系统的可维护性和可扩展性,而且还大大减少了因需求变更而导致的开发成本和时间消耗。随着...
Drools规则引擎是一款强大的开源规则引擎,广泛应用于业务决策逻辑和复杂事件处理。它基于Java平台,由JBOSS组织维护,支持基于 declarative 的规则编写方式,使得非程序员也能理解和修改规则,大大提升了业务规则的...
### 从Drools规则引擎到风控反洗钱系统V0.2.3 #### Drools简介 **1.1 什么是规则引擎** 规则引擎是一种软件组件,它能够从应用程序中独立出来处理业务逻辑和决策制定。通过使用预定义的语义模块来编写这些决策...
3. **规则生命周期**:从创建到执行,Drools规则经历了加载、激活、执行和完成的过程。文档会详细解释这些阶段,以及如何控制规则的触发和执行。 4. **工作内存(Working Memory)**:Drools的工作内存是规则执行的...