March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
hello! I am trying to calculate Employee data as at a point in time.
My Employee data table has report run date and the active employees at each report date. For example
Employee ID | Report Date | Employment Status | Active Status |
1001 | 31/1/2024 | Full Time | Active |
1002 | 31/1/2024 | Part Time | Active |
1001 | 29/2/2024 | Full Time | Terminated |
1002 | 29/2/2024 | Part Time | Active |
My headcount measure for this is
Solved! Go to Solution.
@123abc Thanks for your contribution on this tread.
Hi @ForumDT ,
@123abc provided a solution by creating a calculated column. You can make a little adjustment on the formula of your measure as below to get the expected result.
Headcount =
VAR MaxReportDate =
CALCULATE (
MAX ( 'FACT Workforce Data'[Report Date] ),
ALLSELECTED ( 'FACT Workforce Data' )
)
RETURN
CALCULATE (
DISTINCTCOUNT ( 'FACT Workforce Data'[Employee ID] ),
FILTER (
'FACT Workforce Data',
'FACT Workforce Data'[Report Date] = MaxReportDate
&& 'FACT Workforce Data'[Active Status] = "Active"
)
)
Best Regards
Thank you, however i'm trying to calculate the headcount and categories 'as at'. So i still want Secondment to appear if i am filtering by a date where it is relevant.
It should show up if i am reviewing employee data on or before 31/12/2023 but it shouldnt show up if i am reviewing any dates after this.
Obviously i could achieve this with a simple slicer to select dates, however i want the default behaviour to always show the status as at the Max date of the whole table.
Thank you for the clarification. If you want the default behavior to always show the status as at the maximum date of the whole table while still allowing Secondment to appear if relevant, you can modify the measure accordingly. You can achieve this by creating a calculated column to determine the latest employment status for each employee and then filter based on that column. Here's how you can do it:
Latest_Employment_Status =
VAR CurrentDate = MAX('FACT Workforce Data'[Report Date])
RETURN
CALCULATE(
MAX('FACT Workforce Data'[Employment Status]),
FILTER(
'FACT Workforce Data',
'FACT Workforce Data'[Employee ID] = EARLIER('FACT Workforce Data'[Employee ID]) &&
'FACT Workforce Data'[Report Date] <= CurrentDate
)
)
Headcount =
CALCULATE (
DISTINCTCOUNT ('FACT Workforce Data'[Employee ID]),
'FACT Workforce Data'[Latest_Employment_Status] <> BLANK(),
'FACT Workforce Data'[Latest_Employment_Status] = "Active"
)
With this setup, the 'Latest_Employment_Status' column will always show the latest employment status for each employee up to the maximum date in the dataset. The headcount measure then filters based on this column, ensuring that only active employees are counted based on their latest employment status as of the maximum date. If Secondment is relevant for that date, it will appear accordingly in the 'Latest_Employment_Status' column.
Thank you for taking the time to respond.
I have already explored this with AI assistance to no avail but this probably needs a human review of the image attached and expected outcomes.
I already have a solution as per your latest response however I need it calculated as a measure rather than a static filter.
@123abc Thanks for your contribution on this tread.
Hi @ForumDT ,
@123abc provided a solution by creating a calculated column. You can make a little adjustment on the formula of your measure as below to get the expected result.
Headcount =
VAR MaxReportDate =
CALCULATE (
MAX ( 'FACT Workforce Data'[Report Date] ),
ALLSELECTED ( 'FACT Workforce Data' )
)
RETURN
CALCULATE (
DISTINCTCOUNT ( 'FACT Workforce Data'[Employee ID] ),
FILTER (
'FACT Workforce Data',
'FACT Workforce Data'[Report Date] = MaxReportDate
&& 'FACT Workforce Data'[Active Status] = "Active"
)
)
Best Regards
To address this issue, you need to ensure that you're filtering out the 'Secondment' classification when determining the maximum report date. One way to achieve this is by filtering out rows with 'Employment Status' as 'Secondment' before calculating the maximum date.
Here's how you can modify your DAX expression to achieve this:
Headcount =
VAR MaxReportDate = CALCULATE(MAX('FACT Workforce Data'[Report Date]), 'FACT Workforce Data'[Employment Status] <> "Secondment")
RETURN
CALCULATE(
DISTINCTCOUNT('FACT Workforce Data'[Employee ID]),
'FACT Workforce Data'[Report Date] = MaxReportDate,
'FACT Workforce Data'[Active Status] = "Active"
)
This should give you the headcount of active employees as of the maximum report date excluding the 'Secondment' classification.
If this post helps, then please consider Accepting it as the solution to help the other members find it more quickly.
In case there is still a problem, please feel free and explain your issue in detail, It will be my pleasure to assist you in any way I can.
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
User | Count |
---|---|
19 | |
19 | |
16 | |
8 | |
5 |
User | Count |
---|---|
36 | |
28 | |
16 | |
16 | |
12 |