Pre-processing your data
The application provides a processing callout that precedes any Cognos report generation. Functionally, SQL alone does not suffice to extract data from the database. Performance wise, the query used to extract the data is not fast enough.
This framework allows a developer to implement a Java task that aggregates the data for the specified report before executing the report. The data is populated in a staging table in the application database, used specifically for reporting.
The report preprocessor task must extend
com.workbrain.app.reports.aggregation.DataAggregationTask
so that
the task can perform all the necessary calculations to extract the required data. In
addition, the task can store the extracted data into the core AGG_USER_WRK table or a
custom staging table.
After the task completes, the report will use the data in the staging table to display the required results.
The core application includes these Data and Access classes for the AGG_USER_WRK table:
com.workbrain.app.reports.aggregation.db.AggUserWrkAccess
com.workbrain.app.reports.aggregation.model.AggUserWrkData
Aggregate tasks must be registered in the application database before they are executed as part of a Cognos report. To set up the aggregate task, you must include the full package and class name of the aggregate task when registering the report, or manually add the task to the Cgmap Preproc Task field of the Cognos mapping table in the application.
This table shows the preprocessing implementation classes that are included
in the com.workbrain.app.reports.cognos.aggregation
package:
Core Processing Task | Description |
---|---|
SkdOverrideAuditDataAggregationTask | Preprocessing task that populates the WBI_OVERRIDE_VALUE table with overrides pertaining to schedule edits. |
TSOverrideAuditDataAggregationTask | Preprocessing task that populates the WBI_OVERRIDE_VALUE table with overrides pertaining to timesheet edits. |
MftOvertimeDataAggregationTask | Preprocessing task that populates the AGG_USER_WRK table with all OT data for the specified application users, rolled up to the immediate sub team of the application user's root team. |
WbiUserExecutionTask | Preprocessing task that populates the WBI_USER_EXECUTION table with the application user IDs, along with their corresponding (visible) teams or Employee IDs. |
ABADataAggregationTask | Calls the ABM LeaveDetailService public service API to consolidate an absence's leave details into reportable form. Reportable data is then stored in the ABA_CONS_LEAVE_DTL table. |
BalanceAggregationTask | Preprocessing task that populates the AGG_USER_WRK table with a summary of employee balances at the specified start date. |
BalanceDetailAggregationTask | Preprocessing task that populates the AGG_USER_WRK table with a list of employee balance transactions and the details of those transactions. |
FlattenUserTeamAggregationTask | This task transforms teams from the
default hierarchical structure, which uses parent teams and sub-teams,
to flat teams. It accesses team records in the WORKBRAIN_USER_TEAM
table, transforms them, and stores the results in the
WBI_FLAT_USER_TEAM_TABLE. A start date and end date are considered to
determine team membership. In the metadata model, the query subject WBI_SEC_EMP_BY_TEAM can be used to retrieve employee information. |
ForecastWageCostTask | Preprocesing task that populates the SCHED_COST_DETAIL table with calculated wage costs based on work detail information. |
TeamSchprdAggregationTask | This task determines the current schedule period, next schedule period, and previous schedule periods for teams that the specified employee ID is a member of. This task reads data from WBI_TEAM_SCHPRD_DATE if it exists for the team. If the data is not present because, for example, the team is not scheduled using MVS, the schedule periods are calculated and stored in the WBI_TEAM_SCHPRD_DATE table. |
For more information about the above classes, see the provided Java documentation. If this document is not available, contact Infor Customer Support.