Skip to content

Releases: fivetran/dbt_workday

v0.3.0 dbt_workday

30 Oct 19:39
3cf109b
Compare
Choose a tag to compare

PR #8 includes the following changes:

Breaking Changes

  • Updated the workday__monthly_summary model to segment out inactive employees within the monthly employee and worker active metrics.
    • The model now utilizes the is_active field to filter employees who are active at the end of a month, which are further filtered into active employee and worker metrics, particularly all active_* and avg_* fields.
    • This new logic accounts for employees that move between active and inactive states while still being employed, so avg_days_as_employee and avg_days_as_worker are properly calculated.
    • Removed existing conditions for active metrics as they only handled a subset of employee/worker cases, whereas is_active appears to provide more comprehensive coverage.
  • As these changes will significantly impact the metrics in the monthly summary model, these are defined as breaking changes.

Under The Hood

  • Added consistency and integrity tests within integration tests for workday__monthly_summary and workday__employee_daily_history to ensure proper validation of model changes.
  • Added employee_history_enabled: true variable to integration_tests/dbt_project.yml for testing history model changes and generating docs.

Full Changelog: v0.2.0...v0.3.0

v0.2.0 dbt_workday

03 Apr 22:08
3b5cd5f
Compare
Choose a tag to compare

Lots of major updates! PR #5 includes the following changes:

🚨 Breaking Changes 🚨

  • We are now materializing staging models as ephemeral rather than views, as they are mostly redundant with the source tables and are primarily designed for preparing models for final transformation. Previous staging views will no longer be used and will be considered stale.

🔑 New Primary Key 🔑

  • Created a surrogate key employee_id in workday__employee_overview that combines worker_id, source_relation, position_id, and position_start_date. This accounts for edge cases like when:
    • A worker can hold multiple positions concurrently.
    • A position being held by multiple workers concurrently.
    • A worker being rehired for the same position.

🚀 Feature Updates 🚀

  • We have added three end models in the models/workday_history folder thanks to support from Fivetran's history mode feature. These models provide historical daily data looks into crucial worker/employee Workday models, as well as allowing users to assess monthly summary metrics. These end models include:

    • workday__employee_daily_history: Each record is a daily record in an employee, starting with its first active date and updating up toward either the current date (if still active) or its last active date. This will allow customers to track the daily history of their employees from when they started.

    • workday__monthly_summary: Each record is a month, aggregated from the last day of each month of the employee daily history. This captures monthly metrics of workers, such as average salary, churned and retained employees, etc.

    • workday_worker_position_org_daily_history: Each record is a daily record for a worker/position/organization combination, starting with its first active date and updating up toward either the current date (if still active) or its last active date. This will allow customers to tie in organizations to employees via other organization models (such as workday__organization_overview) more easily in their warehouses.

  • We have added staging history mode models in the models/workday_history/staging folder. This allows customers to utilize the Fivetran history mode feature, which records every version of each record in the source table from the moment this mode is activated in the equivalent tables.

  • These staging models include:

    • stg_workday__personal_information_history: Containing historical records of a worker's personal information.
    • stg_workday__worker_history: Containing historical records of a worker's history.
    • stg_workday__worker_position_history: Containing historical records of a worker's position history.
    • stg_workday__worker_position_organization_history: Containing historical records of a worker's position and organization history.
  • We have then utilized the workday__employee_daily_history model in the models/workday_history folder based off of Fivetran's history mode feature, pulling from Workday HCM source models you can view in the models/workday_history/staging folder.

  • We have kept the stg_workday__worker_position_organization_history model separate, as organizational data is too flexible in Workday to effectively join in the majority of data. We leave it to the customer to use their best judgement in joining this data into other end models in their own warehouse. See the DECISIONLOG for more details.

  • These models are disabled by default due to their size, so you will need to set the below variable configurations for each of the individual models you want to utilize in your dbt_project.yml.

vars:
   employee_history_enabled: true   
  • Users can set a custom employee_history_start_date filter to narrow down the number of historical records they bring into your staging and end models. By default, the package will use the minimum _fivetran_start date to generate the start date for the final daily history models. This default may be overwritten to your liking by leveraging the below variable.
vars:
    employee_history_start_date: 'YYYY-MM-DD' # The first `_fivetran_start` date you'd like to filter data on in all your history models.
  • We have also added the workday__monthly_summary model in the models/workday_history folder. This table aggregates high-level monthly metrics to track changes over time to overall employee data for a customer.

  • We have chosen not to implement incremental logic in the history models due to the future-facing updating of Workday HCM transactions beyond current daily updates. See the DECISIONLOG for more details.

  • Workday HCM History Mode models can contain a multitude of rows if you bring in all historical data, so we've introduced the flexibility to set first date filters to bring in only the historical data you need. More details can be found in the README.

🚘 Under the Hood 🚘

  • Created int_workday__worker_employee_enhanced model to simplify end model processing in the workday__employee_overview, which is now focused on generating the surrogate key.

Full Changelog: v0.1.1...v0.2.0

v0.1.1 dbt_workday

21 Feb 17:40
7f0441e
Compare
Choose a tag to compare

PR #4 contains the following updates:

Bug Fixes

  • Updates the filtering done in the history staging models to pull the correct active statuses. Since some changes are entered but not yet effective, we needed to replace the _fivetran_active filter to where current timestamp is between _fivetran_start and _fivetran_end times for each record.

Under the Hood

  • Switched from using dbt.current_timestamp_backcompat() to dbt.current_timestamp() since the former has since been deprecated and was just previously used to ensure Snowflake and Postgres compatibility.

Full Changelog: v0.1.0...v0.1.1

v0.1.0 dbt_workday

22 Jan 18:46
21c98e2
Compare
Choose a tag to compare

🎉 Initial Release 🎉

This is the initial release of this package!

📣 What does this dbt package do?

This package models Workday HCM data from Fivetran's connector. The main focus of the Workday HCM package is to transform the core object tables into analytics-ready models.

These models materialize Workday HCM staging tables which leverage data in the format described by this ERD.

The staging tables clean, test, and prepare your Workday HCM data from Fivetran's connector for analysis by doing the following:

  • Primary keys are renamed from id to <table name>_id.
  • Adds column-level testing where applicable. For example, all primary keys are tested for uniqueness and non-null values.
  • Provides insight into your Workday HCM data by creating the final end models for further transformation and analysis:
model description
workday__employee_overview Each record represents an employee with enriched personal information and the positions they hold. This helps measure employee demographic and geographical distribution, overall retention and turnover, and compensation analysis of their employees.
workday__job_overview Each record represents a job with enriched details on job profiles and job families. This allows users to understand recruitment patterns and details within a job and job groupings.
workday__organization_overview Each record represents organization, organization roles, as well as positions and workers tied to these organizations. This allows end users to slice organizational data at any grain to better analyze organizational structures.
workday__position_overview Each record represents a position with enriched data on positions. This allows end users to understand position availabilities, vacancies, cost to optimize hiring efforts.
  • Generates a comprehensive data dictionary of your Workday HCM data through the dbt docs site.