User Community Service Desk Downloads
If you can't find the product or version you're looking for, visit support.ataccama.com/downloads

Create DQ Evaluation Rule

For an example of how to create a DQ rule for a specific use case, see Get Started with Data Quality.

Before you start

Check the following topics:

Create new DQ evaluation rule manually

As well as being created from scratch, DQ evaluation rules can be created from the attribute statistics. For example, create a DQ evaluation rule for a the correct format for social insurance numbers using existing masks from profiling results.

Create rule from mask
Mask used in rule

To create a rule:

  1. Navigate to Data Quality > Rules

  2. Click Create.

    Rule listing
  3. Provide the following information:

    • Name: The name of the rule.

    • Description (optional): A description of the rule and how to use it.

    • Rule definition source (optional): A descriptive name for the data source associated with the rule.

    • Stewardship (recommended): Select the user group which are owners of the asset. After you select a group, the list of users assigned to the governance roles within the selected group is displayed.

      For more information, see Stewardship

  4. Click Save to create a draft of the rule.

    New rule missing implementation
  5. Before publishing or submitting an approval request, you need to define the rule logic consisting of at least one input attribute and condition. Continue to Rule implementation.

Rule implementation

Once you have created the rule, go to the Implementation tab

Select rule type

Use the dropdown, and under DQ Evaluation Rules, choose from the following:

Select rule type
  • Validity: Validity rules verify the usability of the data (for example, regarding data format, data content or attribute relations). The default results are Valid and Invalid.

  • Uniqueness: Use this dimension to verify that there are no duplicate values and only one instance appears in the dataset. The default results are Unique, Not populated, and Not Unique.

  • Completeness: Use this dimension to verify that the value field is filled. The default results are Complete and Not complete.

  • Accuracy: Use this dimension to check whether values are accurate and reflect the true values, for example, based on reference data. The default results are Accurate, No reference available, and Not accurate.

  • Timeliness: Use this dimension to verify whether data is available at the time it is needed. The default results are Timeliness ok, Minor delay, and Major delay.

  • Custom: If you have created any custom dimensions, they can also be selected here.

DQ dimensions are fully customizable. Validity, Uniqueness, Accuracy, Completeness, and Timeliness are available by default, but their configuration and results can be changed if required. For more information, see Data Quality Dimensions.

Inputs

  1. Add input attributes by providing names and selecting the data types. Select Add attribute if you require additional fields

    Input attributes are abstract at this point. The number of input attributes defined here and their rule logic become available when you assign rules to catalog items.

    The attribute names can be as you choose and do not affect the implementation.

    Add rule inputs
    If special characters or reserved words are used in input names they must be enclosed in square brackets or publishing fails.
    1. (Optional) Assign terms to the attribute

      Assigning terms to input attributes during implementation results in this rule being suggested by the system in the instance an attribute also has this term.
    2. (Optional) Create Variables from your inputs. Within the Variables section, you can apply a range of transformations to your input attribute. For example, apply the rule conditions only on trimmed versions of string attributes.

      To create variables:

      Add input variables
      • Select a name for your variable. To add fields for additional variables, select Add Variable.

        As with the input attribute names, choose a meaningful name or leave as default.
      • Select the attributes on which the transformations are applied. Use the dropdown to select from the list of input attributes - you apply the transformations in the next step.

        Alternatively, if you are an advanced user, use the dropdown to select Advanced Expression and define the attribute and the transformations using ONE expression language.

        Advanced expression in variables
      • Add transformations using the Add transformation option. The transformations available depend on the data type of the selected attribute: a full list of types and available transformations is provided below.

        You can apply multiple transformations to one attribute, but you can only add them in a sensical sequence. For example, if you start with an attribute of data type String and apply the transformation To integer, you can’t then add the Uppercase transformation, as this is only available on string.

        For the same reason, you can only remove the last transformation in a sequence at any given time. To remove the transformation, hover over the last transformation and use the x to delete.

        Expand to see all available transformations
        Datatype Available transformations Description

        String

        To float

        Changes data type from string to float.

        To integer

        Changes data type from string to integer.

        To long

        Changes data type from string to long.

        Uppercase

        Converts string characters to uppercase.

        Lowercase

        Converts string characters to lowercase.

        Trim

        Removes spaces from both ends of the string.

        Squeeze spaces

        Trims string and replaces repeated spaces with a single space.

        Remove non-digits

        Removes non-digit characters from string.

        Remove non-letters

        Removes non-letter characters from string.

        Integer

        To float

        Changes data type from integer to float.

        To date

        Changes data type from integer to date.

        To long

        Changes data type from integer to long.

        Boolean

        To String

        Changes data type from Boolean to string.

        Date

        To datetime

        Changes data type from date to datetime.

        To string

        Changes data type from date to string.

        Datetime

        To date

        Changes data type from datetime to date.

        To string

        Changes data type from datetime to string.

        Long

        To float

        Changes data type from long to float.

        To string

        Changes data type from long to string.

        To date

        Changes data type from long to date.

        To datetime

        Changes data type from long to datetime.

        Float

        To string

        Changes data type from float to string.

        Floor

        Rounds to the nearest integer that is less than or equal to float value.

        Ceiling

        Rounds to the nearest integer that is greater than or equal to float value.

        Round

        Rounds to nearest integer.

Rule logic

First, select whether you are creating a standard Rule, Aggregation rule, or Component rule.

Component rules need to be created first in ONE Desktop by power users. To add a component rule, select the component from the list of existing components by clicking Select a Component.

The component rule needs to fulfil the following conditions in order to ensure the correct results are returned:

  • The total number of input records must match the total number of output records in the component.

  • The order of output records must match the order of input records.

Aggregation rules require additional configuration, described in Aggregation Rules.

Provide the rule conditions and an explanation of the results. There are two ways to do this: through the Condition Builder or via Advanced Expression:

  • Select Advanced Expression to leverage ONE expressions in your rule condition (see ONE Expressions).

    Advanced expression
  • Select Condition Builder to define the rule logic using the predefined options.

    Condition builder

If you selected Advanced Expression, enter the expression in the space provided and proceed to Test rule.

If you selected Condition Builder:

  1. Select the input attributes to use in the rule logic.

    Select inputs
  2. Select any required modifiers, for example, Trim or Round. Different modifiers are available for string and integer inputs.

    Select modifier
    Expand to see all available modifiers
    Modifier Description

    Value

    The given value of an attribute.

    Uppercase

    Uppercase version of string.

    Lowercase

    Lowercase version of string.

    Trim

    Removes any whitespaces from both sides of strings.

    Trim left

    Removes any leading whitespaces from strings.

    Trim right

    Removes any trailing whitespaces from strings.

    Squared

    Squares the value of an integer, float, or long data type attributes.

    Round

    Rounds the value of an integer, float, or long data type attributes to the nearest whole number.

    Average

    Averages the value of integer, float, or long data type attributes (available only when using aggregation rules and grouping).

    Min

    The minimum of string, integer, or long data types attributes (available only when using aggregation rules and grouping).

    Max

    The maximum of string, integer, or long data type attributes (available only when using aggregation rules and grouping).

    Sum

    The sum of of string, integer, or long data type attributes (available only when using aggregation rules and grouping).

  3. Select the required conditions, for example, matches_mask or has length of, and provide the necessary requirements. The options available depend on the data type of the input attributes.

    Select condition
    Expand to see all available conditions
    Condition Description

    Is empty

    When the input is not filled.

    This checks if the field is filled, but a field is not identified as empty if it is filled with: NULL, Null, null, ., ,, -, _, N/A, n/a, and so on.

    Is not empty

    When the input is filled.

    Is the same as

    When the input is the same as the value you define.

    Is the same as attribute

    When the attribute is the same as the attribute you select.

    Is not the same as

    When the input is not the same as the value you define.

    Is not the same as attribute

    When the attribute is not the same as the attribute you select.

    Is from the following list

    When the attribute belongs to the list you define.

    Is not from the following list

    When the attribute does not belong to the list you define.

    Has length of

    Is the same as the length you define.

    Contains

    When the input contains a substring you define.

    Is from catalog item

    When input belongs to a lookup item built from specified catalog item attribute or reference data in ONE Data.

    To make sure the rule always uses the latest data available, select ON DATA CHANGE in Data updates. If you select a catalog item that is not managed using ONE Data, no automatic updates are available.

    600

    For more information, see Use Lookups in Rules.

    Is not from catalog item

    When input doesn’t belong to a lookup item built from specified catalog item attribute or reference data in ONE Data.

    Is from lookup

    When attribute input belongs to the lookup file you select.

    Is not from lookup

    When attribute input does not belong to the lookup file you select.

    Matches mask

    When input corresponds to the mask you define.

    Does not match mask

    When input does not correspond to the mask you define.

    Matches regexp

    When input corresponds to the regular expression you define.

    Does not match regexp

    When input does not correspond to the regular expression you define.

    Is true

    When Boolean input is true.

    Is false

    When Boolean input is false.

    Is unique

    When aggregated group is unique.

    Is not unique

    When aggregated group is not unique.

  4. Select whether the condition defined should produce the result that is, for example, Valid or Invalid. Options are different depending on the dimension chosen.

    Optionally, enter an explanation to help distinguish between multiple rules of the same dimension.

    Condition result
  5. (Optional) Assign a score to results that are then used during evaluation. See Assigning scores.

Test rule

You can optionally test the rule by clicking Test Rule and trying different inputs in the Test section. The results for each input are shown automatically in Message next to the test input row.

Test rule

Publish rule

After the changes are implemented, they need to be published.

Scoring records

The score is used as a numeric expression of the severity of each record’s invalidity according to the rule. This is mainly useful for monitoring projects to detect the most pressing issues and to be able to improve the data quality.

Scores are arbitrary and can be assigned to suit your project.

Typically, the logic follows that the higher the score, the worse the issue. For example, if a non-critical value is missing, the invalidity score could be 100. If a critical value is missing, the invalidity score could be 10000.

Assigning scores

It is also possible to assign scores via the validation component in ONE Desktop. This is available only for power users.

For more information, see Validation Components.

In the example shown, you have a validity rule in which an invalid record due to errors is considered of higher importance than an invalid record due to a null value, the invalid results being scored at 50 and 500 respectively.

600

Cumulative results of data quality statistics are shown on the Configuration and Results tab of a monitoring project. However, to be able to see the score of each record, it is necessary to export the project.

Next steps

Apply your newly-created DQ rule to a term, or directly to attributes in the data catalog. See Add Rules to Terms and Add DQ Rules to Attributes.

Was this page useful?