Datasets

Last modified: January 3, 2025

Introduction

A dataset is defined using either an OQL query or a custom Java action. To constrain a dataset, parameters can be defined which can be used in the OQL query or Java action.

For one use of a dataset, see Retrieving Objects Using OQL Specified in a Dataset in How to Use Mendix Data Storage APIs to Build Reusable Microflow Actions.

General

Fields for datasets contain the following properties:

  • Name – This is the name of the dataset.
  • Description – This is the description of the dataset, it is only relevant as documentation.

Source

  • OQL query – This is the OQL query which defines the dataset.
  • Java action – This is the interface of the Java action which returns a dataset. The columns and data types of the columns need to be specified in Studio Pro. Based on this specification, Studio Pro will create a template for this action.

The following shows an example OQL query that calculates the aggregated total order amount for all orders of a customer for a specific group of customers:

FROM CRM.Customers As CustomerObj
INNER JOIN CustomerObj/CRM.Orders_Customer/CRM.Orders As OrderObj
WHERE CustomerObj/CRM.Customer_Group = $ParGroup
GROUP BY CustomerObj/Name
SELECT CustomerObj/Name As Name, SUM(OrderObj/TotalAmount) As TotalAmount

Parameters

A dataset can have multiple parameters. Parameters are used to filter / manipulate datasets. Security on datasets is configured based on the parameters. In a Java action, the parameters are used in the generated template.

A parameter has the following configurable properties:

  • Name – This is the name of the parameter.
  • Type – The type of the parameter can be: Boolean, Date and time, Enumeration, Decimal, Integer/Long, or Object.
  • Constraints – The constraints on a parameter influence which values can be selected for parameter input values by the end-user. Constraints can be associated with user roles in dataset security. There are two types of constraints:
    • Ranges which apply to numeric and date parameters
    • XPath constraints which apply to object parameters
  • Ranges – When a parameter is defined as a range, the drop-down box in the report shows each range instead of all values within the ranges. Decimal parameters are always ranges.
  • XPath Constraints – An XPath constraint can be defined using XPath. Multiple constraints can be defined on a parameter and each constraint can be associated with a user role.