DMN tables are powerful tools for modeling and implementing business rules and decision logic.
They allow you to define rules and their associated conditions and actions in a structured manner.
By evaluating the conditions in each rule, the DMN engine can determine which rules are triggered based on the provided inputs and execute the corresponding actions.
This provides a flexible and configurable approach to decision-making in various scenarios.
A DMN (Decision Model and Notation) table consists of several components that help define the decision logic and structure the decision-making process.
- ***Conditions:*** Conditions specify the criteria or constraints that need to be evaluated for each input variable.
They define the rules or expressions that determine when a particular decision rule should be triggered.
Conditions are usually represented in the "When" column of the table.
- ***Actions or Expressions:*** Actions or expressions define the operations or calculations that are executed when a specific rule is triggered.
They represent the logic associated with the decision outcome and are represented in the same row as the conditions in the table.
- ***Decision Rules:*** Decision rules are the individual rows in the DMN table.
Each rule represents a specific combination of conditions and actions that define the behavior or logic for a particular scenario.
Decision rules combine the input conditions and output actions in a structured manner.
- ***Hit Policy:*** The hit policy determines how the decision engine selects or combines the applicable decision rules when multiple rules are triggered.
It defines the behavior for resolving conflicts or overlaps between rules.
Common hit policies include "First," "Unique," "Priority," "Any," and "Collect."
## Using Numeric Ranges in DMN Tables for BPMN Workflows
In BPMN workflows that utilize DMN tables to make decisions based on numerical data, it is crucial to use the correct syntax for specifying numeric ranges.
The recommended syntax for defining numeric ranges in a DMN table is shown in the example. It is straightforward and ensures that the DMN engine evaluates the conditions correctly without errors.
If specifying a numeric range for a decision, use the proper DMN format:
- Incorrect Format: [0..5]
- Correct Format: <=5
Expression for Range:
- For values from 7 to 10 inclusive: 7 <= ? <= 10
- For values from 10 to 12 inclusive: 10 <= ? <= 12
These expressions set up the conditions in a way that the DMN engine can clearly understand and process, ensuring that the workflow behaves as expected based on the input values.