Este contenido no está disponible en el idioma seleccionado.
Chapter 5. Defining decision tables
			Decision table spreadsheets (XLS or XLSX) require two key areas that define rule data: a RuleSet area and a RuleTable area. The RuleSet area of the spreadsheet defines elements that you want to apply globally to all rules in the same package (not only the spreadsheet), such as a rule set name or universal rule attributes. The RuleTable area defines the actual rules (rows) and the conditions, actions, and other rule attributes (columns) that constitute that rule table within the specified rule set. A decision table spreadsheet can contain multiple RuleTable areas, but only one RuleSet area.
		
				You should typically create only one decision table spreadsheet, containing all necessary RuleTable definitions, per rule package in Decision Central. You can create separate decision table spreadsheets for separate packages, but creating multiple decision table spreadsheets in the same package can cause compilation errors from conflicting RuleSet or RuleTable attributes and is therefore not recommended.
			
Refer to the following sample spreadsheet as you define your decision table:
Figure 5.1. Sample decision table spreadsheet for shipping charges
Procedure
- 
					In a new XLS or XLSX spreadsheet, go to the second or third column and label a cell RuleSet(row 1 in example). Reserve the column or columns to the left for descriptive metadata (optional).
- 
					In the next cell to the right, enter a name for the RuleSet. This named rule set will contain allRuleTablerules defined in the rule package.
- 
					Under the RuleSetcell, define any rule attributes (one per cell) that you want to apply globally to all rule tables in the package. Specify attribute values in the cells to the right. For example, you can enter anImportlabel and in the cell to the right, specify relevant data objects from other packages that you want to import into the package for the decision table (in the formatpackage.name.object.name). For supported cell labels and values, see Section 5.1, “RuleSet definitions”.
- 
					Below the the RuleSetarea and in the same column as theRuleSetcell, skip a row and label a new cellRuleTable(row 7 in example) and enter a table name in the same cell. The name is used as the initial part of the name for all rules derived from this rule table, with the row number appended for distinction. You can override this automatic naming by inserting aNAMEattribute column.
- Use the next four rows to define the following elements as needed (rows 8-11 in example): - Rule attributes: Conditions, actions, or other attributes. For supported cell labels and values, see Section 5.2, “RuleTable definitions”.
- Object types: The data objects to which the rule attributes apply. If the same object type applies to multiple columns, merge the object cells into one cell across multiple columns (as shown in the sample decision table), instead of repeating the object type in multiple cells. When an object type is merged, all columns below the merged range will be combined into one set of constraints within a single pattern for matching a single fact at a time. When an object is repeated in separate columns, the separate columns can create different patterns, potentially matching different or identical facts.
- Constraints: Constraints on the object types.
- Column label: (Optional) Any descriptive label for the column, as a visual aid. Leave blank if unused. Note- As an alternative to populating both the object type and constraint cells, you can leave the object type cell or cells empty and enter the full expression in the corresponding constraint cell or cells. For example, instead of - Orderas the object type and- itemsCount > $1as a constraint (separate cells), you can leave the object type cell empty and enter- Order( itemsCount > $1)in the constraint cell, and then do the same for other constraint cells.
 
- After you have defined all necessary rule attributes (columns), enter values for each column as needed, row by row, to generate rules (rows 12-17 in example). Cells with no data are ignored (such as when a condition or action does not apply). - If you need to add more rule tables to this decision table spreadsheet, skip a row after the last rule in the previous table, label another - RuleTablecell in the same column as the previous- RuleTableand- RuleSetcells, and create the new table following the same steps in this section (rows 19-29 in example).
- Save your XLS or XLSX spreadsheet to finish.
				Only the first worksheet in a spreadsheet workbook will be processed as a decision table when you upload the spreadsheet in Decision Central. Each RuleSet name combined with the RuleTable name must be unique across all decision table files in the same package.
			
After you upload the decision table in Decision Central, the rules are rendered as DRL rules like the following example, from the sample spreadsheet:
5.1. RuleSet definitions
				Entries in the RuleSet area of a decision table define DRL constructs and rule attributes that you want to apply to all rules in a package (not only in the spreadsheet). Entries must be in a vertically stacked sequence of cell pairs, where the first cell contains a label and the cell to the right contains the value. A decision table spreadsheet can have only one RuleSet area.
			
				The following table lists the supported labels and values for RuleSet definitions:
			
| Label | Value | Usage | 
|---|---|---|
| 
								 | 
								The package name for the generated DRL file. Optional, the default is  | Must be the first entry. | 
| 
								 | 
								 | Optional, at most once. If omitted, no firing order is imposed. | 
| 
								 | Integer numeric value | Optional, at most once. In sequential mode, this option is used to set the start value of the salience. If omitted, the default value is 65535. | 
| 
								 | Integer numeric value | Optional, at most once. In sequential mode, this option is used to check if this minimum salience value is not violated. If omitted, the default value is 0. | 
| 
								 | 
								 | Optional, at most once. If omitted, quotation marks are escaped. | 
| 
								 | A comma-separated list of Java classes to import from another package. | Optional, may be used repeatedly. | 
| 
								 | Declarations of DRL globals (a type followed by a variable name). Multiple global definitions must be separated by commas. | Optional, may be used repeatedly. | 
| 
								 | One or more function definitions, according to DRL syntax. | Optional, may be used repeatedly. | 
| 
								 | One or more query definitions, according to DRL syntax. | Optional, may be used repeatedly. | 
| 
								 | One or more declarative types, according to DRL syntax. | Optional, may be used repeatedly. | 
					In some cases, Microsoft Office, LibreOffice, and OpenOffice might encode a double quotation mark differently, causing a compilation error. For example, “A” will fail, but "A" will pass.
				
5.2. RuleTable definitions
				Entries in the RuleTable area of a decision table define conditions, actions, and other rule attributes for the rules in that rule table. A decision table spreadsheet can have multiple RuleTable areas.
			
				The following table lists the supported labels (column headers) and values for RuleTable definitions. For column headers, you can use either the given labels or any custom labels that begin with the letters listed in the table.
			
| Label | Or custom label that begins with | Value | Usage | 
|---|---|---|---|
| 
								 | N | 
								Provides the name for the rule generated from that row. The default is constructed from the text following the  | At most one column. | 
| 
								 | I | Results in a comment within the generated rule. | At most one column. | 
| 
								 | C | Code snippet and interpolated values for constructing a constraint within a pattern in a condition. | At least one per rule table. | 
| 
								 | A | Code snippet and interpolated values for constructing an action for the consequence of the rule. | At least one per rule table. | 
| 
								 | @ | Code snippet and interpolated values for constructing a metadata entry for the rule. | Optional, any number of columns. | 
The following sections provide more details about how condition, action, and metadata columns use cell data:
- Conditions
- For columns headed - CONDITION, the cells in consecutive lines result in a conditional element:- First cell: Text in the first cell below - CONDITIONdevelops into a pattern for the rule condition, and uses the snippet in the next line as a constraint. If the cell is merged with one or more neighboring cells, a single pattern with multiple constraints is formed. All constraints are combined into a parenthesized list and appended to the text in this cell.- If this cell is empty, the code snippet in the cell below it must result in a valid conditional element on its own. For example, instead of - Orderas the object type and- itemsCount > $1as a constraint (separate cells), you can leave the object type cell empty and enter- Order( itemsCount > $1)in the constraint cell, and then do the same for any other constraint cells.- To include a pattern without constraints, you can write the pattern in front of the text of another pattern, with or without an empty pair of parentheses. You can also append a - fromclause to the pattern.- If the pattern ends with - eval, code snippets produce boolean expressions for inclusion into a pair of parentheses after- eval.
- Second cell: Text in the second cell below - CONDITIONis processed as a constraint on the object reference in the first cell. The code snippet in this cell is modified by interpolating values from cells farther down in the column. If you want to create a constraint consisting of a comparison using- ==with the value from the cells below, then the field selector alone is sufficient. Any other comparison operator must be specified as the last item within the snippet, and the value from the cells below is appended. For all other constraint forms, you must mark the position for including the contents of a cell with the symbol- $param. Multiple insertions are possible if you use the symbols- $1,- $2, and so on, and a comma-separated list of values in the cells below. However, do not separate- $1,- $2, and so on, by commas, or the table will fail to process.- To expand a text according to the pattern - forall($delimiter){$snippet}, repeat the- $snippetonce for each of the values of the comma-separated list in each of the cells below, insert the value in place of the symbol- $, and join these expansions by the given- $delimiter. Note that the- forallconstruct may be surrounded by other text.- If the first cell contains an object, the completed code snippet is added to the conditional element from that cell. A pair of parentheses is provided automatically, as well as a separating comma if multiple constraints are added to a pattern in a merged cell. If the first cell is empty, the code snippet in this cell must result in a valid conditional element on its own. For example, instead of - Orderas the object type and- itemsCount > $1as a constraint (separate cells), you can leave the object type cell empty and enter- Order( itemsCount > $1)in the constraint cell, and then do the same for any other constraint cells.
- 
									Third cell: Text in the third cell below CONDITIONis a descriptive label that you define for the column, as a visual aid.
- Fourth cell: From the fourth row on, non-blank entries provide data for interpolation. A blank cell omits the condition or constraint for this rule.
 
- Actions
- For columns headed - ACTION, the cells in consecutive lines result in an action statement:- 
									First cell: Text in the first cell below ACTIONis optional. If present, the text is interpreted as an object reference.
- Second cell: Text in the second cell below - ACTIONis a code snippet that is modified by interpolating values from cells farther down in the column. For a singular insertion, mark the position for including the contents of a cell with the symbol- $param. Multiple insertions are possible if you use the symbols- $1,- $2, and so on, and a comma-separated list of values in the cells below. However, do not separate- $1,- $2, and so on, by commas, or the table will fail to process.- A text without any marker symbols can execute a method call without interpolation. In this case, use any non-blank entry in a row below the cell to include the statement. The - forallconstruct is supported.- If the first cell contains an object, then the cell text (followed by a period), the text in the second cell, and a terminating semicolon are strung together, resulting in a method call that is added as an action statement for the consequence. If the first cell is empty, the code snippet in this cell must result in a valid action element on its own. 
- 
									Third cell: Text in the third cell below ACTIONis a descriptive label that you define for the column, as a visual aid.
- Fourth cell: From the fourth row on, non-blank entries provide data for interpolation. A blank cell omits the condition or constraint for this rule.
 
- 
									First cell: Text in the first cell below 
- Metadata
- For columns headed - METADATA, the cells in consecutive lines result in a metadata annotation for the generated rules:- 
									First cell: Text in the first cell below METADATAis ignored.
- 
									Second cell: Text in the second cell below METADATAis subject to interpolation, using values from the cells in the rule rows. The metadata marker character@is prefixed automatically, so you do not need to include that character in the text for this cell.
- 
									Third cell: Text in the third cell below METADATAis a descriptive label that you define for the column, as a visual aid.
- Fourth cell: From the fourth row on, non-blank entries provide data for interpolation. A blank cell results in the omission of the metadata annotation for this rule.
 
- 
									First cell: Text in the first cell below 
5.3. Additional rule attributes for RuleSet or RuleTable definitions
				The RuleSet and RuleTable areas also support labels and values for other rule attributes, such as PRIORITY or NO-LOOP. Rule attributes specified in a RuleSet area will affect all rule assets in the same package (not only in the spreadsheet). Rule attributes specified in a RuleTable area will affect only the rules in that rule table. You can use each rule attribute only once in a RuleSet area and once in a RuleTable area. If the same attribute is used in both RuleSet and RuleTable areas within the spreadsheet, then RuleTable takes priority and the attribute in the RuleSet area is overridden.
			
				The following table lists the supported labels (column headers) and values for additional RuleSet or RuleTable definitions. For column headers, you can use either the given labels or any custom labels that begin with the letters listed in the table.
			
| Label | Or custom label that begins with | Value | 
|---|---|---|
| 
								 | P | 
								An integer defining the  
								Example:  | 
| 
								 | V | 
								A string containing a date and time definition. The rule can be activated only if the current date and time is after a  
								Example:  | 
| 
								 | Z | 
								A string containing a date and time definition. The rule cannot be activated if the current date and time is after the  
								Example:  | 
| 
								 | U | 
								A Boolean value. When this option is set to  
								Example:  | 
| 
								 | G | A string identifying an agenda group to which you want to assign the rule. Agenda groups allow you to partition the agenda to provide more execution control over groups of rules. Only rules in an agenda group that has acquired a focus are able to be activated. 
								Example:  | 
| 
								 | X | A string identifying an activation (or XOR) group to which you want to assign the rule. In activation groups, only one rule can be activated. The first rule to fire will cancel all pending activations of all rules in the activation group. 
								Example:  | 
| 
								 | D | A long integer value defining the duration of time in milliseconds after which the rule can be activated, if the rule conditions are still met. 
								Example:  | 
| 
								 | T | 
								A string identifying either  
								Example:  | 
| 
								 | E | A Quartz calendar definition for scheduling the rule. 
								Example:  | 
| 
								 | F | 
								A Boolean value, applicable only to rules within agenda groups. When this option is set to  
								Example:  | 
| 
								 | L | 
								A Boolean value, applicable only to rules within rule flow groups or agenda groups. When this option is set to  
								Example:  | 
| 
								 | R | A string identifying a rule flow group. In rule flow groups, rules can fire only when the group is activated by the associated rule flow. 
								Example:  | 
Figure 5.2. Sample decision table spreadsheet with attribute columns
 
    